linux - 汇总数据列(个位数)

标签 linux bash gnu-coreutils

我正在寻找一种快速添加数据行的方法,例如

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/

相关文章:

regex - 正则表达式不提取组

linux - 在 linux 中存储一个变量

c++ - 使用 gnu coreutils 在 C++ 中查找 include guard 拼写错误

c++ - 无法让 sigaction 工作

linux - 使用 ls 和 grep 而不是 find 搜索目录和子目录以查找与字符串匹配的文件并列出路径

bash - echo命令,然后运行呢? (喜欢做)

linux - 使用 gnu-coreutils、bash 获取二进制文件的一部分

c - 传递比 C 原型(prototype)中指定的更多的参数

c++ - 在 Mac OS X 上使用 Eclipse CDT 调试远程 Linux 应用程序

linux - 如何在 Debian 中安装 Mono