从多个文件添加列的简单方法

时间:2015-04-01 20:42:29

标签: bash awk paste

如果我有多个这样的文件:

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个文件,然后似乎忽略了其余的文件。

2 个答案:

答案 0 :(得分:6)

您可以使用此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命令。

答案 1 :(得分:1)

我不明白为什么你认为粘贴/ awk解决方案不可行。假设每个文件只有2列,这是你可以做到的一种方法:

paste * | awk '{ s=$2; for(i=4; i<=NF; i+=2) s+=$i; print $1, s }'

输出:

1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5