免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: netlogon
打印 上一主题 下一主题

如何整合三个文件的内容呢? [复制链接]

论坛徽章:
0
11 [报告]
发表于 2009-06-17 20:44 |只看该作者
  1. awk 'ARGIND==1{a[$1]=$2}ARGIND==2{b[$1]=$2}ARGIND==3{print $0,b[$1],a[$2]}' mem name index
复制代码

论坛徽章:
0
12 [报告]
发表于 2009-06-17 20:50 |只看该作者

回复 #10 netlogon 的帖子

得先理解awk的数组啊。


  1. awk 'ARGIND==1{n[$1]=$2}ARGIND==2{m[$1]=$2}ARGIND==3{a[$1]=$2}ARGIND==4{b[$1]=$2}ARGIND==5{print $0,n[$1],m[$2],a[$2],b[$2]}' /tmp/name /tmp/memtatol /tmp/memused /tmp/cpuused /tmp/index
复制代码

论坛徽章:
1
摩羯座
日期:2015-01-08 14:01:55
13 [报告]
发表于 2009-06-17 20:52 |只看该作者
awk 'ARGIND==1{a[$1]=$2}ARGIND==2{b[$1]=$2}ARGIND==3{c[$1]=$2}ARGIND==4{print $0,a[$1],b[$2],c[$2]}' /tmp/name /tmp/memtotal /tmp/memused /tmp/index
依次类推。
由于name文件匹配index的$1,故取a[$1],且name文件输入必须在memtotal,memused前面。
memtotal,memused,cpuused都是匹配index的$2,故取b[$2],c[$2]...
自己多测试下就行了,index文件再弄个$3测试下,多总结下。

论坛徽章:
1
摩羯座
日期:2015-01-08 14:01:55
14 [报告]
发表于 2009-06-17 20:55 |只看该作者
作为输入文件,name必须在memtotal,cpuused前面,memtotal和cpuused的输入顺序可以随意,index必须在最后面。

论坛徽章:
0
15 [报告]
发表于 2009-06-18 17:23 |只看该作者
受用了,感谢
不过理解的还是有点困难
如果现在有这个种情况,又该如何呢?

  1. [root@localhost shell]# cat index
  2. 0 112
  3. 1 16
  4. 2 320
  5. 3 336
  6. 4 48
  7. 5 80
  8. 6 96
  9. [root@localhost shell]# cat name
  10. 0       server1
  11. 1       server2
  12. 2       server3
  13. 3       server4
  14. 4       server5
  15. 5       server6
  16. 6       server7
  17. [root@localhost shell]# cat kbtx
  18. 1 462046
  19. 2 27
  20. 3 704358
  21. 4 661075
  22. 5 703342
  23. 6 239
  24. 7 4942
  25. 8 37
  26. 9 314688
  27. 10 343032
  28. 11 827607

  29. [root@localhost shell]# cat netid
  30. 1 112
  31. 2 112
  32. 3 16
  33. 4 16
  34. 5 336
  35. 6 336
  36. 7 48
  37. 8 48
  38. 9 80
  39. 10 96
  40. 11 96
  41. [root@localhost shell]#
复制代码


需要的结果:
  1. [root@localhost shell]#  cat last
  2. 1 112 0 server1 462046
  3. 2 112 0 server1 27
  4. 3 16 1 server2 704358
  5. 4 16 1 server2  661075
  6. 5 336 2 server3 703342
  7. 6 336 2 server3 239
  8. 7 48 4 server5 4942
  9. 8 48 4 server5  37
  10. 9 80 5 server6 314688
  11. 10 96 6 server7  343032
  12. 11 96 6 server7 827607
复制代码

[ 本帖最后由 netlogon 于 2009-6-18 17:36 编辑 ]

论坛徽章:
1
摩羯座
日期:2015-01-08 14:01:55
16 [报告]
发表于 2009-06-18 20:08 |只看该作者
awk 'ARGIND==1{a[$2]=$1}ARGIND==2{print $0,a[$2]>"last"}' index netid && awk 'ARGIND==1{m[$1]=$2}ARGIND==2{n[$1]=$2}ARGIND==3{print $0,m[$3],n[$1]>"last"}' name kbtx last

awk不熟,数组还得好好研究,这样可以。

论坛徽章:
0
17 [报告]
发表于 2009-06-18 20:12 |只看该作者

回复 #15 netlogon 的帖子

man一下awk,或者找点awk资料看。

ARGIND可以按照C/C++中main函数argv的下标来理解,数组可以按照STL的map来理解。
要处理这类问题,找好对应关系就行了。后面这个问题和前面相比无非就是换了哈希表的key和value而已。


  1. awk 'ARGIND==1{a[$2]=$1}ARGIND==2{b[$1]=$2}ARGIND==3{c[$1]=$2}ARGIND==4{print $0,a[$2],b[a[$2]],c[$1]}' index name kbtx netid
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP