如何将多个数组中的数字相加

如何将多个数组中的数字相加

我有一个包含许多数组的文件,其中第一列中有“标识符”数字。所以我需要根据该“标识符”对第二列中的数字求和。

输入示例:

1: 6.1703
44 10
46 18.3
44 45.9
46 3.9

2: 6.1932
44 11.2
46 4.3
44 15.6319
46 20.12

3: 16.5
45 22.8
45 18.3
46 31

输出需要是:

1: 6.1703
44 55.9
46 22.2

2: 6.1932
44 26.8319
46 24.42

3: 16.5
45 41.1
46 31

答案1

这将完成工作

awk '
    /^[[:blank:]]*$/{for (k in a) print k, a[k]; delete a; print ""; next}
    /:/{print; next}
    {a[$1] += $2}
    END {for (k in a) print k, a[k]}
    ' data

1: 6.1703
44 55.9
46 22.2

2: 6.1932
44 26.8319
46 24.42

3: 16.5
45 41.1
46 31

相关内容