免费注册 查看新帖 |

Chinaunix

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

两个文件之间的替换如何写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-06-06 12:04 |只看该作者 |倒序浏览
file1:
a,0001,0003
b,0003,0002
c,0002,000301
d,0005,0003

file2: (列1和列2字段内容都是唯一的)
0001,bj
0002,tj
0003,sh
000301,shxh
0004,cq
0005,nj


用file2替换结果得到
a,bj,sh
b,sh,tj
c,tj,shxh
d,nj,sh

如果对应规则少,还好办,大不了手工写,但是现在文件记录条数太多,
不得已请大侠们指点一二

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2005-06-06 12:11 |只看该作者

两个文件之间的替换如何写?

awk  'BEGIN{FS=OFS=","}
NR==FNR{a[$1]=$2}
NR>FNR{print $1,a[$2],a[$3]}
' file2 file1

论坛徽章:
0
3 [报告]
发表于 2005-06-06 13:39 |只看该作者

两个文件之间的替换如何写?

我在solaris下运行的结果:
0001,,
0002,,
0003,,
000301,,
0004,,
0005,,
a,,
b,,
c,,
d,,

这不是我想要的,
另外您的这个语句我也不太看得懂,能否稍给解释,我好像没见过a[$1]
这种用法,非常感谢

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
4 [报告]
发表于 2005-06-06 14:09 |只看该作者

两个文件之间的替换如何写?

那请到
http://phi.sinica.edu.tw/aspac/reports/94/94011/ch4.html
去见见吧?

另,读完整个教程也是一个好的开端

论坛徽章:
0
5 [报告]
发表于 2005-06-06 14:24 |只看该作者

两个文件之间的替换如何写?

[quote]原帖由 "lhxu"]钟梅ǎ?浅8行籟/quote 发表:

把你file1中那些多余的空格删掉就对了。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
6 [报告]
发表于 2005-06-06 16:51 |只看该作者

两个文件之间的替换如何写?

好代码,waker!
先读file2生成以第一个字段为键,第二个字段为值的hash表,后面直接查表就完了。
精彩!

论坛徽章:
0
7 [报告]
发表于 2005-06-06 17:38 |只看该作者

两个文件之间的替换如何写?

利害,就是想了半天没搞明白NR==FNR和NR>FNR...

论坛徽章:
0
8 [报告]
发表于 2005-06-08 09:47 |只看该作者

两个文件之间的替换如何写?

现在还是没有搞定,网上一时也找不到a[$1]这种用法,只好厚着脸皮
再次求助,有没有别的地方有相关资料?再次感谢!
还有是不是需要gawk?

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
9 [报告]
发表于 2005-06-08 09:59 |只看该作者

两个文件之间的替换如何写?

俺也怀疑你的文件中有空格或控制字符之类影响
加一句试试

  1. awk  'BEGIN{FS=OFS=","}
  2. {gsub(/[^a-z,0-9]/,"")}
  3. NR==FNR{a[$1]=$2}
  4. NR>FNR{print $1,a[$2],a[$3]}
  5. ' file2 file1
复制代码

论坛徽章:
0
10 [报告]
发表于 2005-06-08 18:48 |只看该作者

两个文件之间的替换如何写?

用了新的语句以后,居然说有语法错了,我怀疑我的awk是不是不太好,
solais2.7,awk版本怎么看?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP