日期:2014-05-16  浏览次数:20699 次

寻求对文件中若干数值进行累加,不用循环的方法
使用命令行工具,如果不用循环的方法能不能对下面文件的每一行进行累加呢:

ora_file.txt:

 1
 10
 12
 14
 56
 78

 2
 3
 5
 7
 8

上面的文件每几行中间有一个空行分隔,我现在要统计1+10+12+...+78 以及 2+3+5...+8的结果,并且输出成如下形式:

结果1

结果2

如果不用循环大家有什么好的办法呢

另外,如果咱们简化一下这个问题,只计算文件中所有数值相加(1+10+12...+8),有没有一个工具呢。

在网上查询AWK写的一个方法带有循环:

#!/usr/bin/awk -f

BEGIN {
RS="" #将多行记录的分隔符定为一个空行
}

{
sum=0 #定义一个表示总和的变量,初值为0
for(i=1;i<=NF;i++){ #遍历所有字段
  sum += $i #累加每个字段的值
}
print sum
}


但是效率相当不满意,求高效方法 :)

非常感谢大家!



------解决方案--------------------
原来也不能用awk的这种循环方法。估计你的文件很大。那自己写一个小程序。

估计效率也不好怎么处理。
------解决方案--------------------
如果是使用gawk,可以设置RS="\0",把整个文件当作一个记录读入,看看看效率如何?
------解决方案--------------------
Perl code
$ awk '/^[ \t]*$/&&sum!=0{print "sum:"sum;sum=0;next}{sum+=$1}' test
sum:171
sum:25

------解决方案--------------------
awk 的效率还不满意,现在耗时如何?
------解决方案--------------------
这样试试呢
按照你的简化要求

echo `tr -s '\n' '+' < yourfile` 0 |bc -l