免费注册 查看新帖 |

Chinaunix

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

[文本处理] awk类似于excel中的sum函数对列进行统计求和的代码哪里错了,请指教。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-11 16:27 |显示全部楼层 |倒序浏览
文件如下:
A01 维护    30  16  9   3  2  30  30  16  9   3  
A02 优化    14  6   1   0  7  14  14  6   1   0  
A03 监控    4   0   3   0  1  4   0   4   0   3  
A09 建设    6   3   0   0  3  6   0   6   3   0  
想在最后填一行合计输出为
A01 维护    30  16  9   3  2  30  30  16  9   3
A02 优化    14  6   1   0  7  14  14  6   1   0
A03 监控    4   0   3   0  1  4   0   4   0   3
A09 建设    6   3   0   0  3  6   0   6   3   0
TOTAL 合计 54        25        13        3         13        54        44        32        13        6
即从第3列开始至列12进行分列统计,统计结果放在最后一行。
以下为我写的代码
gawk "BEGIN{for (n=3;n<=12;n++) sum(n)=0;b=\"\"}{for (n=3;n<=12;n++) sum(n)+=$n,b=b\" \"sum(n);print $0}END{print \" TOTAL\" , \" 合计\",b}" tongji.txt
结果在sum(n)+=$n,b=b\" \"sum(n)之间的逗号出现如下错误
syntax error
请问哪里出错了?

论坛徽章:
0
2 [报告]
发表于 2013-09-11 16:55 |显示全部楼层
回复 2# 关阴月飞


   
请看图片,实际的代码是sum[n]+=$n。

论坛徽章:
0
3 [报告]
发表于 2013-09-11 17:10 |显示全部楼层
回复 3# dn833


    经测试,能实现要求,多谢。这段代码能否解释一下,不是很明白 for(j=3;j<=NF;j++)printf a[j]" ";print ""}

论坛徽章:
0
4 [报告]
发表于 2013-09-11 18:09 |显示全部楼层
回复 7# cao627


    多谢多谢,算是明白了一点 for 后面的语句如有多条,要用{}括起,又学了一招。

论坛徽章:
0
5 [报告]
发表于 2013-09-12 17:21 |显示全部楼层
for(j=3;j<=NF;j++)printf a[j]" ";print ""}不是i和j的问题,是我没搞懂各列的和为何输出在同一行上,看了reyleon的代码算是搞懂了。for(i=3;i<=NF;i++)printf a[i] OFS; 妙在这个OFS上,多谢各位耐心指点,收益非浅。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP