免费注册 查看新帖 |

Chinaunix

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

[文本处理] 求教两个文件对比合并(替换)的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-04-13 13:03 |只看该作者 |倒序浏览
现在有个主文件,内容简单列为:

file1:
name activity
name1 we eat
name2 we dance;we eat
name3 we are happy
name4 we eat
name5 we are happy
name6 we are happy

现在想把 activity 这一列用数字代码表示,file2:
activity code
we eat 1
we are happy 2
we dance;we eat 3

替换(或者合并)为
name code
name1  1
name2  3
name3  2
name4 1
name5 2
name6 2

求教怎么用awk 操作,谢谢!!!

论坛徽章:
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
2 [报告]
发表于 2017-04-13 13:18 |只看该作者
本帖最后由 jason680 于 2017-04-13 13:28 编辑

回复 1# aaronportman

$ awk 'FNR==NR{c=$NF;NF--;a[$0]=c;next}{n=$1;$1="";sub("^ +","");print n,(a[$0]!="")?a[$0]:$0}' f2 f1
name code
name1 1
name2 3
name3 2
name4 1
name5 2
name6 2

论坛徽章:
0
3 [报告]
发表于 2017-04-13 14:24 |只看该作者
回复 2# jason680

谢谢大神!

可否麻烦大神给解释一下这一行code 的意思啊,不胜感激!

论坛徽章:
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 [报告]
发表于 2017-04-13 15:00 |只看该作者
本帖最后由 jason680 于 2017-04-13 15:02 编辑

回复 3# aaronportman

用C来写,百行有之

先看...

awk初学之常见问题
http://bbs.chinaunix.net/thread-2309494-1-1.html


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP