免费注册 查看新帖 |

Chinaunix

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

求助一个awk合并 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-03-11 15:24 |只看该作者 |倒序浏览
本帖最后由 zjdick 于 2011-03-11 15:33 编辑

a b 1 10
a b 2 12
a c 1 100
a c 2 1000
a d 1 9
a d 2 8
如何合并成
a b 10 12
a c 100 1000
a d 9 8
awk了半天,没得出个办法,头大了。

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
2 [报告]
发表于 2011-03-11 15:51 |只看该作者
echo "a b 1 10
a b 2 12
a c 1 100
a c 2 1000
a d 1 9
a d 2 8
" |awk '{printf ($1 FS $2 !=v?"\n"$1 FS $2 FS $NF:FS $NF);v=$1 FS $2}'

a b 10 12
a c 100 1000
a d 9 8

论坛徽章:
0
3 [报告]
发表于 2011-03-11 15:55 |只看该作者
回复 1# zjdick


    awk '{a[$1$2]=a[$1$2]" "$4}END{for(j in a)print j,a[j]}'

论坛徽章:
0
4 [报告]
发表于 2011-03-11 16:11 |只看该作者
额的神啊,高人啊。
这个没看懂,有没有高人解释下:
awk '{printf ($1 FS $2 !=v?"\n"$1 FS $2 FS $NF:FS $NF);v=$1 FS $2}'

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
5 [报告]
发表于 2011-03-11 16:30 |只看该作者
awk '{if( $1 FS $2 !=v) {printf "\n"$1 FS $2 FS $NF} else {printf FS $NF}}{v=$1 FS $2}'
这样可能好理解,功能和上面的一样

论坛徽章:
0
6 [报告]
发表于 2011-03-11 16:43 |只看该作者
回复 5# yinyuemi


    额,懂了,多谢多谢。

论坛徽章:
0
7 [报告]
发表于 2011-03-11 17:29 |只看该作者
awk '{a[$1" "$2]=a[$1" "$2]" " $4}END{for(i in a) print i,a[i]}' file
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP