简单的问题:我必须编写一个简单的脚本,其中一部分是将列中的每个值相加 -> 每列和所有内容的总和。所以文件
1 2 5
1 2
1
应该返回
column1: 3
column2: 4
column3: 5
sum: 12
我的代码几乎完美,但列没有按升序显示
if [[ $# -eq 0 ]]; then
awk '{ for (i=1;i<=NF;i++) sum[i]+=$i }; END { for (i in sum) print "column "i" : " sum[i];}' file.txt
awk '{for(i=1;i<=NF;i++) sum+=$i;}; END {print "sum: " sum}' file.txt
fi
输出是:
➜ script ./sum.sh
column 2 : 4
column 3 : 5
column 1 : 3
sum: 12
为什么从第 2 列开始?
答案1
for (variable in array)
应迭代,以未指定的顺序将数组的每个索引分配给变量。
解决方案
if [[ $# -eq 0 ]]; then
awk '(NF>m){m=NF}{for(i=1;i<=NF;i++)sum[i]+=$i}END{for(i=1;i<=m;i++)print("column "i" : "sum[i])}' file.txt
awk '{for(i=1;i<=NF;i++)sum+=$i}END{print("sum: "sum)}' file.txt
fi
输出
column 1 : 3
column 2 : 4
column 3 : 5
sum: 12