我正在寻找一种快速添加数据行的方法,例如
3333456332....
3334456332....
3343446332....
3331355332....
(但更长)并将每个数字加到这个结果中:
12 12 13 11 15 19 22 12 12 4
这是否可能使用单线?还是更复杂?
最佳答案
来点 awk 怎么样:
awk -v FS="" '{for(i=1; i<=NF; ++i) a[i]+=$i} END {for (i=1; i<=NF; ++i) printf "%d ", a[i] }' file
这将创建一个数组 a
累加每个数字的所有总和。在 END
文件,遍历数组并打印所有总和。
FS
变量在这里很重要,因为它意味着行中的每个数字都被视为一个单独的字段。
输出:
12 12 13 11 15 19 23 12 12 8
更新
上面的代码不会在求和后打印换行符,这可能正是您想要的。正如 fedorqui 的评论中所建议的那样,一种方法是:
awk -v FS="" '{for (i=1; i<=NF; ++i) a[i]+=$i} END {for (i=1; i<=NF; ++i) printf "%d%s", a[i], (i<NF?" ":"\n") }' file
它在所有值之间打印一个空格,然后在末尾打印一个换行符。
或者,如果您喜欢连接字符串,您可以这样做:
awk -v FS="" '{for(i=1; i<=NF; ++i) a[i]+=$i} END{for (i=1; i<=NF; ++i) s=s a[i] " "; print s}' file
首先构建一个字符串 s
然后 print
是它。 print
默认情况下会为您添加换行符。
灵感来自 choroba's answer , 这是使用 Perl 的替代版本:
perl -F'' -wane 'pop @F; $i=0; $s[$i++]+=$_ for @F }{ print "@s\n"' file
与 awk 一样,将字段分隔符设置为 ''
.使用“自动拆分”开关 -a
创建数组 @F
, 每个元素包含一个数字。
@F
的最后一个元素是换行符"\n"
, 所以 pop
删除它。数组 @s
保留所有的总和。 -n
switch 表示整个命令都包含在 while (<>) { ... }
中, 所以使用 }{
“爱斯基摩人运算符(operator)”有效地创建了一个 END
堵塞。 通过设置特殊变量 $"
到一个空间$"
默认是空格,所以可以一次性打印数组,每个元素之间用空格隔开。
关于linux - 汇总数据列(个位数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23806206/