免费注册 查看新帖 |

Chinaunix

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

怎样用awk进行分段统计累加  关闭 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-02-27 20:06 |只看该作者 |倒序浏览
有如下文本:

业务流水帐      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号…………

论坛徽章:
0
2 [报告]
发表于 2005-02-27 20:58 |只看该作者

怎样用awk进行分段统计累加

begin{
}
{if($0 ~ /业务流水帐/){
  dipartment=$4;
  count1=0;
  count2=0;
  while(getline){
       if($0 ~ /^本项合计/){
          count1 = count1+$2;
          count2 = count2+$3;
          }
       if($0 ~ /----------/){
          break;
       }
   }
  print departmen"  "count1"  "count2"\n";
}
}
end{
}

论坛徽章:
0
3 [报告]
发表于 2005-02-27 23:54 |只看该作者

怎样用awk进行分段统计累加

/^业务流水帐/{i=0;department=$4;num1=0;num2=0}
/--------/{i++; if (i==2) print department, num1, num2}
/^本项合计/{num1+=$2;num2+=$3}

论坛徽章:
0
4 [报告]
发表于 2005-02-28 08:59 |只看该作者

怎样用awk进行分段统计累加

to 卡龙1980:打印出两行0;
to launch401:只打印出01部门的统计数

论坛徽章:
0
5 [报告]
发表于 2005-02-28 10:01 |只看该作者

怎样用awk进行分段统计累加

业务流水帐 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
---------------------------

应该是这种文本就能打印出两行了。就是每个部门的记录都用----线开始和结束

论坛徽章:
0
6 [报告]
发表于 2005-02-28 11:03 |只看该作者

怎样用awk进行分段统计累加

to launch401,如果文本中没有------,怎样处理

论坛徽章:
0
7 [报告]
发表于 2005-02-28 11:12 |只看该作者

怎样用awk进行分段统计累加

#!/bin/sh
#get what information wanting

grep -E "业务流水账|本项合计" a.txt|awk 'BEGIN {i=0}
                                         {if($0~/业务流水账/)
                                            {i=i+1}
                                                            else
                                            { if($0~/本项合计/)
                                                {a+=$2}
                                            }
                                          }
                                         END {for(j=1;j<=i;j++)
                                               {print j"号"": "a[j]}
                                             }'

现在在学习AWK,有不正确的地方,请DX多多帮忙!!

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
8 [报告]
发表于 2005-02-28 11:28 |只看该作者

怎样用awk进行分段统计累加

  1. awk ' /业务流水帐/{ n=$4; if(!ind[i]){ind[i++]=n;}}
  2. /本项合计/{sum[n]+=$3;}
  3. END{for(j=0;j<i;j++){print "部门:",ind[j],"合计:",sum[ind[j]];}}'
复制代码

论坛徽章:
0
9 [报告]
发表于 2005-02-28 16:43 |只看该作者

怎样用awk进行分段统计累加

GOOD,收!还是Waker厉害,利用数组,又很简单,谢了。同时谢参与的各位!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP