我有一个包含许多数组的文件,其中第一列中有“标识符”数字。所以我需要根据该“标识符”对第二列中的数字求和。
输入示例:
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