从多个文件添加列的简单方法
Simple way to add columns from multiple files
如果我有多个这样的文件:
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 , +}'
可以,但是超过20个文件就不行了。我也试过使用
awk 'NR==FNR{a[NR]=;next}{print ,+a[FNR]}' filename1.txt filename2.txt
但它只适用于 2 个文件,然后似乎忽略了其余文件。
你可以使用这个awk
:
awk '{a[FNR]=; s[FNR]+=} 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 命令。
我不明白您为什么认为 paste/awk 解决方案不可行。这是一种方法,假设每个文件只有 2 列:
paste * | awk '{ s=; for(i=4; i<=NF; i+=2) s+=$i; print , s }'
输出:
1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5
如果我有多个这样的文件:
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 , +}'
可以,但是超过20个文件就不行了。我也试过使用
awk 'NR==FNR{a[NR]=;next}{print ,+a[FNR]}' filename1.txt filename2.txt
但它只适用于 2 个文件,然后似乎忽略了其余文件。
你可以使用这个awk
:
awk '{a[FNR]=; s[FNR]+=} 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 命令。
我不明白您为什么认为 paste/awk 解决方案不可行。这是一种方法,假设每个文件只有 2 列:
paste * | awk '{ s=; for(i=4; i<=NF; i+=2) s+=$i; print , s }'
输出:
1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5