前段时间刚完成了一个测试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 ($i=="w/s") {print i}}}' ssd.log
awk '{for (i=1;i<=NF;i++) {if ($i=="wMB/s") {print i}}}' ssd.log
如果引用变量的话 需要用"’ '"双引号加单引号的模式
awk '{for (i=1;i<=NF;i++) {if ($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 $3}'|awk 'BEGIN{min='$max'} {if ($1<min) min=$1;fi} END{printf "%.1f\n",min}'
($max的值需要大于等于此列数据的最大值)
6 求百分比
awk ‘BEGIN{printf “%.2f%%\n”,(‘
n
u
m
1
′
/
′
num1'/'
num1′/′num2’)*100}’(保留2位小数)
7 比较大小
echo 1 2 |awk '{if($1 > $2) print "pass";else print "failed"}'
8 加减乘除
echo 10 2 |awk ‘{print $1+$2}’
echo 10 2 |awk ‘{print $1-$2}’
echo 10 2 |awk ‘{print $1*$2}’
echo 10 2 |awk ‘{print $1/$2}’