免费注册 查看新帖 |

Chinaunix

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

关于AWK 的处理文件内容 [复制链接]

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
1 [报告]
发表于 2011-08-09 18:18 |显示全部楼层
连续的两行(用户ID , 邮箱 )可以用 大的金额减去小得金额然后输出运算结果,
不连续的直接输出结果就可以 ...
cczn 发表于 2011-08-09 17:37



$ echo '用户ID , 邮箱 ,金额
-------------------------
123456,abc@test.com,105
123456,abc@test.com,205
111111,hhh@163.com,200
111111,hhh@163.com,300
144888,test1@test1.com,500
144999,test2@test2.com,100' | awk -F, '/^[0-9]/{m[$1]=a[$1]?m[$1]-$33;a[$1]=$1","$2}END{for(x in m)print a[x]","(m[x]>0?m[x]:-m[x])}'
111111,hhh@163.com,100
144999,test2@test2.com,100
123456,abc@test.com,100
144888,test1@test1.com,500

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2011-08-10 15:31 |显示全部楼层
回复  jason680


    谢谢 您的回复,昨天我说的不是很明白,您现在这个是最大值减去小得  我现在需要 ...
cczn 发表于 2011-08-10 13:25



$ awk -F, '/^[0-9]/{t=$1","$2;if(m[t]==""{m[t]=$3" OK";c++}else{m[t]=$3-m[t]}a[c]=t}END{for(n=0;n++<cprint a[n]","m[a[n]]}' file2.txt     
444444,ppp@pppp.com,100 OK
555555,ooo@oooo.com,100 OK
123456,abc@test.com,100
999999,zzz@163.com,300 OK
111111,hhh@163.com,100
144888,test1@test1.com,500 OK
144999,test2@test2.com,100 OK
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP