免费注册 查看新帖 |

Chinaunix

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

[文本处理] 二个文本的内容对比后重新生成内容 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-05-17 22:18 |只看该作者 |倒序浏览
深夜不知道大家是不是都在休息了。
碰到一个比较难的问题,请教一下如何对比二个文件内容,并且抓出我想要的信息呢?

文本一的内容:
cat hsotname.txt
aaa 10.10.10.1  lab users1
bbb 10.10.10.2  lab users2

文本二的内容
cat mac.txt
Internet  10.10.10.1             176   2894.0f04.aaff  ARPA   Vlan102
Internet  10.10.10.2               -   2894.0f04.8dff  ARPA   Vlan102



我希望的结果是这样:
get.txt
aaa 10.10.10.1 2894.0f04.aaff Vlan001
bbb 10.10.10.2 2894.0f04.8dff Vlan001



先谢过大家了!!!

论坛徽章:
0
2 [报告]
发表于 2017-05-18 09:45 |只看该作者
早上好,哪位大侠能指点一下?谢谢啦!

论坛徽章:
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
3 [报告]
发表于 2017-05-18 10:36 |只看该作者
  1. awk 'NR==FNR{a[$2]=$4" "$6}NR>FNR{print $1,$2,a[$2]}' mac.txt hostname.txt > get.txt
复制代码

论坛徽章:
1
程序设计版块每日发帖之星
日期:2015-12-17 06:20:00
4 [报告]
发表于 2017-05-18 10:46 |只看该作者
awk '{if(NR==FNR){ a[$2]=$1" "$2 ;} else {if(a[$2]) print a[$2],$4,$6} }' hostname.txt mac.txt

论坛徽章:
0
5 [报告]
发表于 2017-05-18 14:36 |只看该作者
回复 3# Shell_HAT

谢谢您了。再请教一下,
如果mac.txt和 hsotname.txt每列是用";"号做分隔, ;号的前面可能有空格,您的脚本能相应修改吗
像这样:

cat hostname.txt
aaa; 10.10.10.1;  lab; users1
bbb ;  10.10.10.2;    lab   ;  users2


cat mac.txt
Internet ;  10.10.10.1      ;      176  ; 2894.0f04.aaff ; ARPA  ; Vlan102
Internet    ; 10.10.10.2      ;         -  ;  2894.0f04.8dff  ; ARPA    ; Vlan102



谢谢!!!!

论坛徽章:
0
6 [报告]
发表于 2017-05-18 14:38 |只看该作者
回复 4# vagrant_1220

谢谢,得到我想要的数据了,另外请问一下。如果二文本每行的数据是用 “;” 号来分隔,“;” 号前面可能有一个或多个的空格。那我怎么得到我想要的数据呢?

再次感谢您的帮助!

论坛徽章:
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
7 [报告]
发表于 2017-05-18 14:47 |只看该作者
回复 5# yexingqi


  1. awk -F '[; ]+' 'NR==FNR{a[$2]=$4" "$6}NR>FNR{print $1,$2,a[$2]}' mac.txt hostname.txt > get.txt
复制代码

论坛徽章:
0
8 [报告]
发表于 2017-05-23 15:40 |只看该作者
回复 7# Shell_HAT

谢谢您的回复!!!

论坛徽章:
24
申猴
日期:2014-10-10 15:56:39射手座
日期:2014-10-10 15:57:18黑曼巴
日期:2018-05-14 11:05:122016科比退役纪念章
日期:2018-05-14 11:05:0715-16赛季CBA联赛之北控
日期:2018-05-14 11:05:0015-16赛季CBA联赛之江苏
日期:2017-02-27 18:11:0715-16赛季CBA联赛之上海
日期:2018-08-15 09:48:5415-16赛季CBA联赛之佛山
日期:2018-07-20 17:14:2315-16赛季CBA联赛之佛山
日期:2019-09-10 18:08:4615-16赛季CBA联赛之山西
日期:2020-03-26 09:40:5115-16赛季CBA联赛之佛山
日期:2020-05-08 09:03:54
9 [报告]
发表于 2017-05-25 14:40 |只看该作者
awk 'NR==FNR{a[$2]=$1" "$2}NR!=FNR{print a[$2],$3,$4}' a.txt b.txt

论坛徽章:
0
10 [报告]
发表于 2017-05-26 19:58 |只看该作者
回复 9# chengchow

谢谢您!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP