中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: [求助]用gawk按列求和 上一主题 | 下一主题
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『楼 主』:  [求助]用gawk按列求和

一文本,有上万行,内容类似如下.
序号,机构号,金额,姓名,客户号,五级
1,5416,350000,熊清喜,48260000140870,次级
2,5416,50000,杨小平,48260000142862,次级
3,5416,4500,杨明成,48260000144168,次级
4,5417,7000,蒲猛,48260000144266,次级
5,5418,10000,杨小平,48260000142862,可疑
6,5417,5000,张瑞东,48260000145752,可疑
7,5417,500000,杨明成,48260000144168,可疑
8,5419,200000,张瑞东,48260000145752,损失
9,5417,25000,杨小平,48260000142862,正常
10,5417,15000,蒲猛,48260000144266,正常
我需要将同一客户号(第五列)的金额(第3列)相加,并插入到客户号列后。

处理后如下:
序号,机构号,金额,姓名,客户号,余额,五级
1,5416,350000,熊清喜,48260000140870,350000,次级
2,5416,50000,杨小平,48260000142862,85000,次级
3,5416,4500,杨明成,48260000144168,504500,次级
4,5417,7000,蒲猛,48260000144266,22000,次级
5,5418,10000,杨小平,48260000142862,85000,可疑
6,5417,5000,张瑞东,48260000145752,205000,可疑
7,5417,500000,杨明成,48260000144168,504500,可疑
8,5419,200000,张瑞东,48260000145752,205000,损失
9,5417,25000,杨小平,48260000142862,85000,正常
10,5417,15000,蒲猛,48260000144266,22000,正常
因为该文本较大(20M以上),要求用gawk或其它能快速处理文本的命令处理。
求高手相助。先谢了。

2011-1-3 01:46
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
dooomer
初级用户





积分 109
发帖 52
注册 2006-1-3
状态 离线
『第 2 楼』:  

用excel就可以了吧。gawk就不知道怎么处理了。

2011-1-6 08:24
查看资料  发短消息 网志   编辑帖子  回复  引用回复
freeants001
中级用户




积分 330
发帖 244
注册 2006-4-14
来自 湖北
状态 离线
『第 3 楼』:  


BEGIN{
        FS=",";OFS=",";
        while(getline<ARGV[1]>0)arr[$4]+=$3;       
}
{
        print$1,$2,$3,$4,$5,(NR>1?arr[$4]:"余额"),$6;
}
[ Last edited by freeants001 on 2011-1-6 at 16:53 ]

2011-1-6 16:41
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: