linux中基于两个键合并两个长度不等的文件
我有两个不同长度的txt文件。
File 1:
Albania 20200305 0
Albania 20200306 0
Albania 20200307 0
Albania 20200308 0
Albania 20200309 3
Albania 20200310 7
Albania 20200311 4
Albania 20200312 2
File 2:
Europe Albania 20200309 2
Europe Albania 20200310 6
Europe Albania 20200311 10
Europe Albania 20200312 11
Europe Albania 20200313 23
Europe Albania 20200314 33
如果 File1 的第 1 和第 2 列与 File2 的第 2 和第 3 列相同,我想创建一个 File3,它将在 File2 的末尾添加 File1 的 3. 列。它应该是这样的:
File3:
Europe Albania 20200309 2 3
Europe Albania 20200310 6 7
Europe Albania 20200311 10 4
Europe Albania 20200312 11 2
我试过了
awk 'NR==FNR{A[$1,$2]=$3;next} (($2,$3) in A) {print $0, A[$1,$2]}' file1.txt file2.txt > file3.txt
但它只是打印文件 2,它没有添加文件 1 的第三列。
你能帮我解决这个问题吗?
提前致谢!
回答
您的方法是正确的,但是在打印时您需要使用 like A[$2,$3],您使用的A[$1,$2]是数组 A 中不存在的(因为 file1 的第 1、2 列应与 file2 的第 2 列和第 3 列进行比较),因此它仅打印当前行值文件 3 中的文件 2。
awk 'NR==FNR{a[$1,$2]=$3;next} (($2,$3) in a) {print $0, a[$2,$3]}' file1 file2
另请参阅链接(感谢 James 在这里提供了很好的链接)为什么我们不应该使用大写字母的变量