免费注册 查看新帖 |

Chinaunix

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

两文件合并求助 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-09-13 22:11 |只看该作者 |倒序浏览
30可用积分
现有2个文件,文件file1有2列,内容如:
no1   name1
no2   name2
no3   name2
no4   name3
no5   name4
no6   name4
no7   name4
no8   name5
no9   name6
no10   name6

文件file2 有6列,部分有空格,内容如下:
name1  data1    dada2    data3    data4    dada5
name2               dada6    data7                 dada8
name3  data9    dada10               data11  dada12
name4                                          data13  dada14
name5  data15  dada16  
name6  data17                              data18

如果file1的第2列跟file2的第1列匹配,则将两条数据合并成一条,
合并后的数据应该是这样的:

no1     name1  data1    dada2    data3    data4    dada5
no2     name2               dada6    data7                 dada8
no3     name2               dada6    data7                 dada8
no4     name3  data9    dada10               data11  dada12
no5     name4                                          data13  dada14
no6     name4                                          data13  dada14
no7     name4
no8     name5  data15  dada16  
no9     name6  data17                              data18
no10   name6  data17                              data18

请教下各位,看看怎么实现,谢谢

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
2 [报告]
发表于 2010-09-13 22:11 |只看该作者
  1. awk 'NR==FNR{a[$1]=$0}NR>FNR{print $1" "a[$2]}' file2 file1
复制代码

论坛徽章:
0
3 [报告]
发表于 2010-09-13 22:57 |只看该作者
谢谢,Shell_HAT  的回答,可以解释下
awk 'NR==FNR{a[$1]=$0}NR>FNR{print $1" "a[$2]}' file2 file1
这个命令吗?

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
4 [报告]
发表于 2010-09-13 23:35 |只看该作者
回复 3# leezer


awk处理多个文件时的执行过程
http://bbs.chinaunix.net/viewthr ... ;page=2#pid12383055

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
5 [报告]
发表于 2010-09-14 15:14 |只看该作者

一个老问题了,再看看这个,囧!!!

本帖最后由 expert1 于 2010-09-14 15:20 编辑

用某一文件的一个域替换另一个文件中的的特定域?
文件passwd:
s2002408030068:527:527::/home/dz02/s2002408030068:/bin/pw
s2002408032819:528:528::/home/dz02/s2002408032819:/bin/pw
s2002408032823:529:529::/home/dz02/s2002408032823:/bin/pw

文件shadow:
s20024080300681$d8NwFclG$v4ZTacfR2nsbC8BnVd3dn1:12676:0:99999:7:::
s20024080328191$UAvNbHza$481Arvk1FmixCP6ZBDWHh0:12676:0:99999:7:::
s20024080328231$U2eJ3oO1$bG.eKO8Zupe0TnyFhWX9Y.:12676:0:99999:7:::

用shadow文件中的密文部分替换passwd中的"x",生一个新passwd文件,如下所示
s20024080300681$d8NwFclG$v4ZTacfR2nsbC8BnVd3dn1:527:527::/home/dz02/s2002408030068:/bin/pw
s20024080328191$UAvNbHza$481Arvk1FmixCP6ZBDWHh0:528:528::/home/dz02/s2002408032819:/bin/pw
s20024080328231$U2eJ3oO1$bG.eKO8Zupe0TnyFhWX9Y.:529:529::/home/dz02/s2002408032823:/bin/pw

awk 'BEGIN{OFS=FS=":"} NR==FNR{a[$1]=$2}NR>FNR{$2=a[$1];print}' shadow passwd

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
6 [报告]
发表于 2010-09-14 15:17 |只看该作者
类似拼接paste,join一样,处理第一个文件的时候把某些合适的部分放到数组里面,处理第二个文件的时候,根据需要做一些处理,需要用到刚才的数组。这样2个文件就被拼接起来了。

论坛徽章:
0
7 [报告]
发表于 2010-09-14 22:01 |只看该作者
学习了,谢谢各位!

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
8 [报告]
发表于 2010-09-15 09:06 |只看该作者
囧,o(╯□╰)o

论坛徽章:
0
9 [报告]
发表于 2010-09-16 14:39 |只看该作者
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP