两个不同文件中的总和数

时间:2013-04-13 09:26:20

标签: bash shell awk

我有两个相同长度的文件,如:

0.99952 0.01
0.98927 0.02
0.98242 0.03

-0.758 0.01
-0.745 0.02
-0.742 0.03

我想将第一列数字相加并将其打印在一个新文件中,并在第二列中包含相同的元素。输出应为:

0.24152 0.01
0,24427 0.02
0,24042 0.03

我试过

 paste file1 file2 | awk '{print ($1 + $2), $4}' > sum

但输出是:

 1.00952 0.01
 1.00927 0.02
 1.01242 0.03

2 个答案:

答案 0 :(得分:7)

您在awk中使用无效参数编号($ 2而非$ 3)

$1      $2      $3     $4
0.99952 0.01    -0.758 0.01
0.98927 0.02    -0.745 0.02
0.98242 0.03    -0.742 0.03

有一个有效的例子:

paste data1 data2 | awk '{print ($1 + $3), $4}'

答案 1 :(得分:7)

awk方法:

$ awk 'NR==FNR{a[NR]=$1;next}{print $1+a[FNR],$2}' file1 file2
0.24152 0.01
0.24427 0.02
0.24042 0.03