首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用awk比较和替换字段

如何使用awk比较和替换字段
EN

Stack Overflow用户
提问于 2016-04-23 14:41:03
回答 1查看 183关注 0票数 0

我有两份文件。如果File-1的Field-9与File-2的Field-1相同,则用File-1的Field-2替换File-1的Field-1

file1:

代码语言:javascript
复制
12345||||||756432101000||756432||||
aaaaa||||||986754812345||986754||||
ccccc||||||134567222222||134567||||

file2:

代码语言:javascript
复制
756432|AAAAAAAAAAA  
986754|20030040000  

预期输出为:

代码语言:javascript
复制
12345||||||AAAAAAAAAAA||756432||||
aaaaa||||||20030040000||986754||||
ccccc||||||134567222222||134567|||

我试过这段代码

代码语言:javascript
复制
awk -F"|" 'NR==FNR{a[$1]=$2} NR>FNR{$7=a[$2];print}' OFS='|'  file2 file1

但它并没有替换这个字段,而是被删除了。

EN

回答 1

Stack Overflow用户

发布于 2016-04-23 14:56:27

在第二个块中,您使用了错误的列作为数组的索引,并且没有检查缺少的键。这将生成您发布的输出:

代码语言:javascript
复制
awk -F '|' -v OFS='|' 'NR==FNR{a[$1]=$2;next}$9 in a{$7=a[$9]}1' file2 file1
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36807574

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档