前段时间刚完成了一个测试nvme的项目,其中里边有些脚本需要用到awk求一些平均值,最大值,以及对应的字符之类的,为了方便以后查看方便,在这里总结一下。
1 求字符串所在的列
awk ‘{for (i=1;i<=NF;i++) {if ($i==“string”) {print i}}}’
比如 :
求"w/s","wMB/s"所在的列数:
awk ‘{for (i=1;i<=NF;i++) {if (KaTeX parse error: Expected 'EOF', got '}' at position 20: …w/s") {print i}}̲}' ssd.log awk…i==“wMB/s”) {print i}}}’ ssd.log
如果引用变量的话 需要用"’ ‘“双引号加单引号的模式
awk ‘{for (i=1;i<=NF;i++) {if (
i
=
=
"
′
i=="'
i=="′iops’”) {print i}}}’
2 求平均值
awk ‘{sum+=$1} END {printf “%3.3f\n”,sum/NR}’
3 求最大值
awk ‘BEGIN{ max = 0} {if ($1 > max) max = $1; fi} END{printf “%.1f\n”,max}’
4 求和
awk ‘{sum+=$1} END {printf “%3.3f\n”,sum}’
5 求最小值
awk ‘{print KaTeX parse error: Expected 'EOF', got '}' at position 2: 3}̲'|awk 'BEGIN{mi…max’} {if ($1<min) min=KaTeX parse error: Expected 'EOF', got '}' at position 5: 1;fi}̲ END{printf "%.…max的值需要大于等于此列数据的最大值)
6 求百分比
awk ‘BEGIN{printf “%.2f%%\n”,(‘
n
u
m
1
′
/
′
num1'/'
num1′/′num2’)*100}’(保留2位小数)