中国DOS联盟

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

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

中国DOS联盟论坛
现在时间是 2026-06-25 01:36
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [求助]用gawk按列求和 查看 1,560 回复 2
楼 主 [求助]用gawk按列求和 发表于 2011-01-03 01:46 ·  中国 四川 南充 电信
初级用户
★★
积分 100
发帖 80
注册 2008-09-12 15:08
17年会员
UID 125478
性别 男
状态 离线
一文本,有上万行,内容类似如下.

序号,机构号,金额,姓名,客户号,五级
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或其它能快速处理文本的命令处理。
求高手相助。先谢了。
2 发表于 2011-01-06 08:24 ·  中国 浙江 温州 乐清市 电信
初级用户
★★
积分 109
发帖 52
注册 2006-01-03 22:47
20年会员
UID 48392
状态 离线
用excel就可以了吧。gawk就不知道怎么处理了。
3 发表于 2011-01-06 16:41 ·  中国 湖北 黄石 电信
中级用户
★★
积分 330
发帖 244
注册 2006-04-14 14:07
20年会员
UID 53823
性别 男
来自 湖北
状态 离线

BEGIN{
FS=",";OFS=",";
while(getline<ARGV>0)arr+=$3;
}
{
print$1,$2,$3,$4,$5,(NR>1?arr:"余额"),$6;
}


[ Last edited by freeants001 on 2011-1-6 at 16:53 ]
论坛跳转: