ccccf 发表于 2023-4-13 16:25:39

linux基本文件操作

若A文件的第4列有与B文件的第1列字符相同的字符,则输出A文件的1,2,3,4列与B文件的第5列

isdkz 发表于 2023-4-13 16:33:14

要实现这个功能,你可以使用Linux命令行工具awk。首先,确保你的A文件和B文件是使用空格或制表符分隔的列。假设A文件名为fileA.txt,B文件名为fileB.txt,我们可以使用以下命令:

awk 'NR==FNR {a[$1]=$5; next} $4 in a {print $1, $2, $3, $4, a[$4]}' fileB.txt fileA.txt > output.txt


解释:


[*]NR==FNR:当记录数(NR)等于文件记录数(FNR)时,即仅处理第一个文件(fileB.txt)。
[*]{a[$1]=$5; next}:将第一个文件的第1列作为数组a的键,第5列作为对应的值。next表示处理下一行。
[*]$4 in a:当第二个文件(fileA.txt)的第4列值在数组a中存在时,执行后面的代码块。
[*]{print $1, $2, $3, $4, a[$4]}:打印第二个文件的1,2,3,4列,以及数组a中以第4列值为键的对应值(即B文件的第5列)。
[*]> output.txt:将结果输出到名为output.txt的文件中。


运行这个命令后,你会得到一个名为output.txt的文件,包含满足条件的A文件的1,2,3,4列与B文件的第5列。

大裤衩子 发表于 2023-4-13 16:42:57

默认制表符分割:
awk 'NR==FNR {a[$1]=$5; next} $4 in a {print $1,$2,$3,$4,a[$4]}' B.txt A.txt
页: [1]
查看完整版本: linux基本文件操作