免费注册 查看新帖 |

Chinaunix

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

[文本处理] 两个不一样行数的文件相比,第一列相等则合并 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-04-04 04:52 |只看该作者 |倒序浏览
file1的内容为:
3 sdd
2 sdc
4 sde
5 sdf
1 sdb
0 sda
file2的内容为
0 14 SAS
0 13 SATA
1 9  SATA
2 8  SAS
3 11 SATA
4 12 SATA
5 10 SAS
想得到file3
sda 14 SAS
sda 13 SATA
sdb 9  SATA
sdc 8  SAS
sdd 11 SATA
sde 12 SATA
sdf 10 SAS

论坛徽章:
28
2015年迎新春徽章
日期:2015-03-04 10:16:53午马
日期:2015-03-20 17:11:07亥猪
日期:2015-03-20 17:11:23戌狗
日期:2015-03-20 17:11:33酉鸡
日期:2015-03-20 17:11:47申猴
日期:2015-03-20 17:11:58未羊
日期:2015-03-20 17:12:10子鼠
日期:2015-03-20 17:12:23丑牛
日期:2015-03-20 17:12:40卯兔
日期:2015-03-20 17:12:51辰龙
日期:2015-03-20 17:13:00巳蛇
日期:2015-03-20 17:13:12
2 [报告]
发表于 2015-04-04 08:08 |只看该作者
本帖最后由 我是一隻羊 于 2015-04-04 08:08 编辑
  1. awk 'NR==FNR{a[$1]=$2;next}$1=a[$1]' inputfile1 inputfile2
复制代码

论坛徽章:
0
3 [报告]
发表于 2015-04-04 10:17 |只看该作者
也可以用这个方法:
sort ./file1 > ./file1new  
sort ./file2 > ./file2new
join -1 1 -2 1 ./file1new ./file2new
就可以了

论坛徽章:
1
2015亚冠之鹿岛鹿角
日期:2015-05-12 13:04:44
4 [报告]
发表于 2015-04-04 21:27 |只看该作者
  1. awk 'NR==FNR{a[$1]=$2;next}$1 in a{$1=a[$1];print $0}' file1 file2
复制代码

求职 : 机器学习
论坛徽章:
79
2015年亚洲杯纪念徽章
日期:2015-05-06 19:18:572015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之阿尔纳斯尔
日期:2015-09-07 09:30:232015亚冠之萨济拖拉机
日期:2015-10-21 08:26:3915-16赛季CBA联赛之浙江
日期:2015-12-30 09:59:1815-16赛季CBA联赛之浙江
日期:2016-01-10 12:35:21技术图书徽章
日期:2016-01-15 11:07:2015-16赛季CBA联赛之新疆
日期:2016-02-24 13:46:0215-16赛季CBA联赛之吉林
日期:2016-06-26 01:07:172015-2016NBA季后赛纪念章
日期:2016-06-28 17:44:45黑曼巴
日期:2016-06-28 17:44:4515-16赛季CBA联赛之浙江
日期:2017-07-18 13:41:54
5 [报告]
发表于 2015-04-04 23:18 |只看该作者
如果第一列,第一个文件里有而第二个文件文件没有,这样处理行吗?回复 3# 我是一隻羊


   

论坛徽章:
10
2015年亚洲杯之科威特
日期:2015-04-13 13:51:5315-16赛季CBA联赛之山东
日期:2016-01-16 18:35:0815-16赛季CBA联赛之广东
日期:2016-01-04 15:26:23程序设计版块每日发帖之星
日期:2015-11-13 06:20:002015亚冠之阿尔艾因
日期:2015-11-10 12:32:242015亚冠之阿尔沙巴布
日期:2015-05-15 18:26:49羊年新春福章
日期:2015-04-28 16:45:112015年亚洲杯之伊拉克
日期:2015-04-25 20:06:30羊年新春福章
日期:2015-04-13 13:53:2015-16赛季CBA联赛之八一
日期:2016-01-20 18:23:49
6 [报告]
发表于 2015-04-04 23:55 |只看该作者
手上没有linux,windows写的
  1. awk "NR==FNR{a[$1]=$2;next}NR>FNR{if(a[$1])$1=a[$1]}1" file1.txt file2.txt
复制代码
如果linux运行,双引号换成单引号即可

论坛徽章:
28
2015年迎新春徽章
日期:2015-03-04 10:16:53午马
日期:2015-03-20 17:11:07亥猪
日期:2015-03-20 17:11:23戌狗
日期:2015-03-20 17:11:33酉鸡
日期:2015-03-20 17:11:47申猴
日期:2015-03-20 17:11:58未羊
日期:2015-03-20 17:12:10子鼠
日期:2015-03-20 17:12:23丑牛
日期:2015-03-20 17:12:40卯兔
日期:2015-03-20 17:12:51辰龙
日期:2015-03-20 17:13:00巳蛇
日期:2015-03-20 17:13:12
7 [报告]
发表于 2015-04-05 16:27 |只看该作者
回复 6# zsszss0000


    肯定不行啊~~不存在的行不会输出的~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP