正则表达式 – 使用awk计算并打印通过正则表达式获得的值的平均值

我有一个名为bt.B.1.log的文件,如下所示:

.
.
.
Time in seconds =                   260.37
.
.
.
Time in seconds =                   260.04
.
.
.

等等,以秒为单位显示40个时间记录(点代表无用的行).
我应该从文件中提取那些时间,并在不使用中间文件的情况下计算/打印平均值到.dat文件(t1avg.dat).
我已经能够使用中间文件这样做:

awk '/Time in seconds/ {print $5}' bt.B.1.log > t1.dat
awk '{sum+=$0} END {print sum/NR}' t1.dat > t1avg.dat

因此,该方法是以某种方式将第一个awk命令中出现的正则表达式作为第二个命令中的参数传递,告诉awk计算正则表达式的结果行的总和,所有读取来自单个文件(bt.B .1.log)并写入t1avg.dat(禁止创建t1.dat).到目前为止,我已经达到了以下代码,它给出了错误的输出:

awk '{sum+=/Time in seconds/$5; print sum/NR}' bt.B.1.log

有任何想法吗?

最佳答案
awk '/Time in seconds/ {s+=$5;c++} END{print s/c}' bt.B.1.log >t1avg.dat

s是时间的总和,c是计数.因此,s / c是平均值.

转载注明原文:正则表达式 – 使用awk计算并打印通过正则表达式获得的值的平均值 - 代码日志