LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 943|回复: 5

shell能否做到此事?

[复制链接]
发表于 2006-12-28 19:26:13 | 显示全部楼层 |阅读模式
在一个带有数据的文本中,有两列数据,分为A列B列,可否搜索A列中相同的两个编码(有很多个相同的编码),求出B列对应的数值的和

请赐教!
发表于 2006-12-28 22:53:31 | 显示全部楼层
cnt=0; for l in `cat tp|grep aa|cut -f2 -d' '`; do  cnt=`expr $cnt + $l`; done; echo $cnt
6
回复 支持 反对

使用道具 举报

发表于 2006-12-28 23:04:02 | 显示全部楼层

  1. [0 No.2006 huan@huan ~/tmp]$ cat txt
  2. a 1
  3. a 2
  4. b 3
  5. b 4

  6. [0 No.2007 huan@huan ~/tmp]$ perl -lwane ' $list{ $F[0] } += $F[1]; END{ print "$_ -> $list{$_}" foreach ( sort keys %list) } ' < txt
  7. a -> 3
  8. b -> 7

  9. [0 No.2008 huan@huan ~/tmp]$

  10. [0 No.2005 huan@huan ~/tmp]$
复制代码

像这样的问题
最好是有份示例数据
要不我们也只好猜测LZ了意思了:)
回复 支持 反对

使用道具 举报

发表于 2006-12-29 00:36:37 | 显示全部楼层

  1. awk '{sum[$1]+=$2}END{for(i in sum)print i"->"sum[i]}'
复制代码

精华区里有的是~
回复 支持 反对

使用道具 举报

发表于 2006-12-29 09:13:16 | 显示全部楼层
关联数组简单多了,有启发。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-12-29 11:27:00 | 显示全部楼层
谢谢大家,问题已经解决,用的是perl -lwane ' $list{ $F[0] } += $F[1]; END{ print "$_ -> $list{_}" foreach ( sort keys %list) } ' < txt

谢谢HUAN
以及各位回贴的兄弟!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表