免费注册 查看新帖 |

Chinaunix

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

[文本处理] 怎样用awk进行分段统计累加 [复制链接]

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-29 23:52 |只看该作者 |倒序浏览
原文地址
有如下文本:

业务流水帐      2004年12月28日      部门: 1号
--------------------------------------------------------------------------
A4                 2                  60.00
A3                 3                  120.00
B16                6                  90.00

本项合计:             11                 270.00

16列单            10                  400.00
16列双             2                   100.00

本项合计               12                   500.00
------------------------------------------------------------------------
业务流水帐      2004年12月28日      部门: 2号
--------------------------------------------------------------------------
A4                 1                  30.00
A3                 2                  80.00
B15                4                  60.00

本项合计:         7                 170.00

16列单            5                  200.00
16列双             2                   100.00

本项合计           7                   300.00
.
.
.
..

希望通过简短的awk计算得出如下结果(即把每个部门的“本项合计”统计累加):
1号       23             770.00
2号       14             470.00
3号……………..
4号…………

附上自己的代码;
注释:对文本中的“部门”,“本项合计”分别修改为'dept','total'。
  1. awk '/dept/{i++;a[i]=$4;next}/total/{x[i]+=$2;y[i]+=$3}END{for(j=1;j<=i;j++)print a[j],x[j],y[j]}'
复制代码

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
2 [报告]
发表于 2013-09-30 08:40 |只看该作者
i++可以放到数组里面
  1. awk '/部门/{a[++i]=$4;next}/本项合计/{x[i]+=$2;y[i]+=$3}END{for(j=1;j<=i;j++)print a[j],x[j],y[j]}' urfile
复制代码

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
3 [报告]
发表于 2013-09-30 08:42 |只看该作者
  1. awk '/dept/{No=$NF}/total/{num[No]=+$2;sum[No]+=$3}END{for (i in num) print i, num[i], sum[i]}' infile
复制代码

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
4 [报告]
发表于 2013-09-30 21:41 |只看该作者
赞;回复 3# rdcwayx


   

论坛徽章:
0
5 [报告]
发表于 2013-10-04 14:50 |只看该作者
chen@ubuntu:~$ cat awk.txt
业务流水帐      2004年12月28日      部门: 1号
--------------------------------------------------------------------------
A4                 2                  60.00
A3                 3                  120.00
B16                6                  90.00

本项合计:             11                 270.00

16列单            10                  400.00
16列双             2                   100.00

本项合计               12                   500.00
------------------------------------------------------------------------
业务流水帐      2004年12月28日      部门: 2号
--------------------------------------------------------------------------
A4                 1                  30.00
A3                 2                  80.00
B15                4                  60.00

本项合计:         7                 170.00

16列单            5                  200.00
16列双             2                   100.00

本项合计           7                   300.00
chen@ubuntu:~$ awk 'BEGIN{RS="部门:"}NR>1{print $1," ",$13+$22," ", $14+$23}' awk.txt
1号   23   770
2号   14   470
chen@ubuntu:~$
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP