免费注册 查看新帖 |

Chinaunix

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

[文本处理] 求助 a.txt与b.txt 文件比对,字符分割,替换字符组 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-02-15 16:44 |只看该作者 |倒序浏览
本帖最后由 zhenglin86 于 2016-02-15 16:53 编辑

大家好,本人没什么思路,想在这里询一下处理方法。

a.txt字符如下:

"root":"pass1"
"root2":"pass2"
"root3":"pass3"
"root4":"pass4"
...

b.txt字符如下:


"root":"pass1111"
"root21231":"pass2222"
"root3":"pass3333"

...


想得到的结果
a和b两个文件,以冒号“:”进行数据分割。a和b文件比对,
如果两个文件左边数据root比中,择替换pass1为pass1111
如果两个文件左边数据root4在b文件中没有找到,择不做处理。
如果两个文件左边数据root21231在a文件中没有找到,也不做处理。
最终得到的数据是
"root":"pass1111"  --比中,从b.txt取值替换a.txt
"root2":"pass2"     --b.txt文件没有此值,不做处理
"root3":"pass3333" --比中,从b.txt取值替换a.txt
"root4":"pass4"   --b.txt文件没有此值,不做处理
...

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
2 [报告]
发表于 2016-02-15 17:24 |只看该作者
  1. awk -F: 'NR==FNR || $1 in a{a[$1]=$2}END{for(i in a)print i":"a[i]}' a b
复制代码

论坛徽章:
0
3 [报告]
发表于 2016-02-15 22:47 |只看该作者
本帖最后由 zhenglin86 于 2016-02-15 23:10 编辑

运行了你的shell后,得到的结果如下:
[root@test ~]# awk -F: 'NR==FNR || $1 in a{a[$1]=$2}END{for(i in a)print i":"a}' a.txt b.txt
"root2":"pass2"
"root3":"pass3333"
"root4":"pass4"
"root":"pass1111"

可是为什么排序root不是最上面,而跑到了最下面来了?有什么优化按txt的顺序来进行的吗?
还有:如果有txt中有特殊字符如:"root"="pass{0}",如何将{0}视为文本字符?

回复 2# haooooaaa


   

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
4 [报告]
发表于 2016-02-16 03:02 |只看该作者

What You Think Is What You Get. WYTIWYG

想得到的结果
a和b两个文件,以冒号“:”进行数据分割。a和b文件比对,
如果两个文件左边数据root比中,择替换pass1为pass1111
如果两个文件左边数据root4在b文件中没有找到,择不做处理。
如果两个文件左边数据root21231在a文件中没有找到,也不做处理。
最终得到的数据是
"root":"pass1111"  --比中,从b.txt取值替换a.txt
"root2":"pass2"     --b.txt文件没有此值,不做处理
"root3":"pass3333" --比中,从b.txt取值替换a.txt
"root4":"pass4"   --b.txt文件没有此值,不做处理

$ awk  'BEGIN{FS=OFS=":"}FNR==NR{a[$1]=$2;next}{if(a[$1]!="")$2=a[$1];print $0}' b.txt a.txt
"root":"pass1111"
"root2":"pass2"
"root3":"pass3333"
"root4":"pass4"

论坛徽章:
0
5 [报告]
发表于 2016-02-16 12:37 |只看该作者
回复 4# jason680


    真不错,是我想要的结果,非常感谢大牛。


混论坛,长知识。对新人真不错。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP