我有两份文件。如果File-1的Field-9与File-2的Field-1相同,则用File-1的Field-2替换File-1的Field-1
file1:
12345||||||756432101000||756432||||
aaaaa||||||986754812345||986754||||
ccccc||||||134567222222||134567||||file2:
756432|AAAAAAAAAAA
986754|20030040000 预期输出为:
12345||||||AAAAAAAAAAA||756432||||
aaaaa||||||20030040000||986754||||
ccccc||||||134567222222||134567|||我试过这段代码
awk -F"|" 'NR==FNR{a[$1]=$2} NR>FNR{$7=a[$2];print}' OFS='|' file2 file1但它并没有替换这个字段,而是被删除了。
发布于 2016-04-23 14:56:27
在第二个块中,您使用了错误的列作为数组的索引,并且没有检查缺少的键。这将生成您发布的输出:
awk -F '|' -v OFS='|' 'NR==FNR{a[$1]=$2;next}$9 in a{$7=a[$9]}1' file2 file1https://stackoverflow.com/questions/36807574
复制相似问题