如果我有多个这样的文件:
filename1.txt
# 0.2
1.0 0.0
1.5 1.0
2.0 0.8
2.5 1.1
filename2.txt
# 0.5
1.0 0.1
1.5 0.6
2.0 1.3
2.5 0.4
他们的所有第一列都相同。我只想要一个输出:
# 0.7
1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5
我知道
paste filename1.txt filename2.txt | awk '{print $1, $2+$4}'
可以,但是当文件超过20个时,这是不可行的。我也尝试使用
awk 'NR==FNR{a[NR]=$2;next}{print $1,$2+a[FNR]}' filename1.txt filename2.txt
但它仅适用于2个文件,然后似乎忽略了其余文件。
您可以使用awk
:
awk '{a[FNR]=$1; s[FNR]+=$2} END{for (i=1; i<=FNR; i++) print a[i], s[i]}' file1 file2
# 0.7
1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5
FNR
每个文件从1开始,因此您可以将所有输入文件传递给此awk命令。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句