忘记密码   免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 1375 | 回复: 3

[文本处理] 请教文件中第一列相同的数据拼成一行怎么实现? [复制链接]

论坛徽章:
0
发表于 2018-06-01 16:54 |显示全部楼层
如下数据:
1|a
1|b
1|c
2|a
2|b
2|c
....

想得到数据:
1|abc
2|abc
....

论坛徽章:
3
CU十四周年纪念徽章
日期:2017-08-28 17:16:1915-16赛季CBA联赛之北控
日期:2018-03-29 11:39:0615-16赛季CBA联赛之上海
日期:2018-05-21 10:46:10
发表于 2018-06-01 17:29 |显示全部楼层
本帖最后由 龙牙地主天 于 2018-06-01 17:33 编辑

回复 1# alunfirst

  1. awk -F'|' '{a[$1]=a[$1]?a[$1]$2:$0}END{PROCINFO ["sorted_in"] = "@ind_num_asc" ; for(i in a) print a[i]}' file
复制代码

论坛徽章:
0
发表于 2018-06-01 19:55 |显示全部楼层
  1. awk -vFS="\174" '{a[$1]=a[$1]?a[$1]""$2:$2}END{for(i in a){print i"\174"a[i]}}' file
复制代码

论坛徽章:
13
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之青岛
日期:2018-06-08 13:45:2815-16赛季CBA联赛之同曦
日期:2018-06-04 19:42:2015-16赛季CBA联赛之山东
日期:2018-05-30 12:44:59CU十四周年纪念徽章
日期:2018-05-15 11:36:3815-16赛季CBA联赛之广东
日期:2018-05-14 09:52:4215-16赛季CBA联赛之深圳
日期:2018-05-04 21:53:0815-16赛季CBA联赛之辽宁
日期:2018-04-02 14:03:3915-16赛季CBA联赛之北京
日期:2018-03-23 15:24:07CU十四周年纪念徽章
日期:2018-03-16 13:09:532016科比退役纪念章
日期:2018-01-19 12:45:5915-16赛季CBA联赛之同曦
日期:2017-09-11 14:39:48
发表于 2018-06-04 20:46 |显示全部楼层
回复 1# alunfirst


  1. awk 'BEGIN{FS=OFS="|"}!a[$1]++{if(c){print c,b[c]};c=$1}{b[c]=b[c]?b[c]""$2:$2}END{if(c){print c,b[c]}}' file
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:wangnan@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP