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

Iza*_*son 4 bash awk paste

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

filename1.txt

# 0.2
1.0 0.0
1.5 1.0
2.0 0.8
2.5 1.1
Run Code Online (Sandbox Code Playgroud)

filename2.txt

# 0.5
1.0 0.1
1.5 0.6
2.0 1.3
2.5 0.4
Run Code Online (Sandbox Code Playgroud)

所有第一列都相同的地方.我只想要一个输出:

# 0.7
1.0 0.1
1.5 1.6
2.0 2.1
2.5 1.5
Run Code Online (Sandbox Code Playgroud)

我知道

paste filename1.txt filename2.txt | awk '{print $1, $2+$4}'
Run Code Online (Sandbox Code Playgroud)

但是当有超过20个文件时它是不可行的.我也试过用

awk 'NR==FNR{a[NR]=$2;next}{print $1,$2+a[FNR]}' filename1.txt filename2.txt
Run Code Online (Sandbox Code Playgroud)

但它只适用于2个文件,然后似乎忽略了其余的.

anu*_*ava 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
Run Code Online (Sandbox Code Playgroud)

FNR 从每个文件的1开始,因此您可以将所有输入文件传递给此awk命令.

  • 好吧,你快了几秒钟.:P (2认同)
  • `awk '文件名 ~ /filename9|filename10/ {next} {a[FNR]=$1; s[FNR]+=$2} END{for (i=1; i&lt;=FNR; i++) 打印 a[i], s[i]}' 文件名*` (2认同)