免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1959 | 回复: 6
打印 上一主题 下一主题

请教怎样用awk求平均值?谢了! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-07-19 20:25 |只看该作者 |倒序浏览
有一文本:
001    100    10
001    200    20
001    300    30
001    400    40
002    10     100
002    20     200
002    30     300
002    40     400
对此文本想根据$1相同的行,分别求$2和$3的平均值,按以下结果输出,请问用awk怎么做?
结果:
001   500   50
002   50     500

论坛徽章:
0
2 [报告]
发表于 2003-07-19 20:52 |只看该作者

请教怎样用awk求平均值?谢了!

awk  -F" " '{a[$1]=a[$1]+$2;c[$1]=c[$1]+$3;b[$1]=b[$1]+1} END {for(i in a) print i,a/b,c/b}'   yourfile

论坛徽章:
0
3 [报告]
发表于 2003-07-19 21:27 |只看该作者

请教怎样用awk求平均值?谢了!

哇!侠客级的zhangyo1557,太谢谢了!真是高!我怎么就没想到b[$1]=b[$1]+1;
再次感谢!

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
4 [报告]
发表于 2003-07-20 08:40 |只看该作者

请教怎样用awk求平均值?谢了!

[quote]原帖由 "zhangyo1557"]awk -F" " '{a[$1]=a[$1]+$2;c[$1]=c[$1]+$3;b[$1]=b[$1]+1} END {for(i in a) print i,a/b,c/b}' yourfile [/quote 发表:

思路很好,还可以进一步简化:
awk -F" " '{a[$1]+=$2;c[$1]+=+$3;b[$1]+=1} END {for(i in a) print i,a/b,c/b}' yourfile

论坛徽章:
0
5 [报告]
发表于 2003-07-20 21:23 |只看该作者

请教怎样用awk求平均值?谢了!

谢了!!

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
6 [报告]
发表于 2003-07-21 00:25 |只看该作者

请教怎样用awk求平均值?谢了!

存下来

论坛徽章:
0
7 [报告]
发表于 2003-07-21 07:57 |只看该作者

请教怎样用awk求平均值?谢了!

[quote]原帖由 "admirer"]rfile[/quote 发表:
     
awk -F" " '{a[$1]+=$2;c[$1]+=+$3;b[$1]+=1} END {for(i in a) print i,a/b,c/b}' yourfile


TO ADMIRER:加红了的部分多了个"+";哈哈.改正过来吧~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP