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

前端之家收集整理的这篇文章主要介绍了正则表达式 – 使用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是平均值.

猜你在找的正则表达式相关文章