免费注册 查看新帖 |

Chinaunix

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

[文本处理] 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
请问哪里出错了?

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
2 [报告]
发表于 2013-09-11 16:35 |只看该作者
sum[n]+=$n  

论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
3 [报告]
发表于 2013-09-11 16:44 |只看该作者
  1. awk '{for(i=3;i<=NF;i++)a[i]+=$i;print $0}END{printf "TOTAL heji ";for(j=3;j<=NF;j++)printf a[j]" ";print ""}'
复制代码

论坛徽章:
0
4 [报告]
发表于 2013-09-11 16:55 |只看该作者
回复 2# 关阴月飞


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

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
5 [报告]
发表于 2013-09-11 17:07 |只看该作者
回复 4# Ienovo_qq


{for (n=3;n<=12;n++) sum(n)+=$n,b=b  这里应该是" ; " 号

你这个代码就别折腾了,用楼上的吧。  

论坛徽章:
0
6 [报告]
发表于 2013-09-11 17:10 |只看该作者
回复 3# dn833


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

论坛徽章:
6
摩羯座
日期:2013-08-24 10:43:10狮子座
日期:2013-08-25 10:27:06天秤座
日期:2013-09-11 20:28:44午马
日期:2014-09-28 16:06:0015-16赛季CBA联赛之八一
日期:2016-12-19 13:55:0515-16赛季CBA联赛之天津
日期:2016-12-20 14:01:23
7 [报告]
发表于 2013-09-11 17:14 |只看该作者
本帖最后由 cao627 于 2013-09-11 17:16 编辑

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

实在要用你的意思就用上面的。
红色部分可要可不要
蓝色的b=""是必须的,否则你的b就一串很长的数字了。
@Ienovo_qq

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
8 [报告]
发表于 2013-09-11 17:17 |只看该作者
本帖最后由 reyleon 于 2013-09-11 17:19 编辑
  1. awk '{for(i=3;i<=NF;i++)a[i]+=$i;print}END{printf "Total 合计";for(i=3;i<=NF;i++)printf a[i] OFS;printf RS}' file
复制代码
搞错了

论坛徽章:
0
9 [报告]
发表于 2013-09-11 18:09 |只看该作者
回复 7# cao627


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

论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
10 [报告]
发表于 2013-09-12 09:08 |只看该作者
回复 6# Ienovo_qq


    其实写i写j都一样啦完全是个人习惯而已~~~~就是最后再通过for循环提取出数组中的每个值而已~剩下的printf我觉得对lz来说应该不成问题的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP