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 在这里提供了很好的链接)为什么我们不应该使用大写字母的变量


以上是linux中基于两个键合并两个长度不等的文件的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>