awk进阶

以前用awk通常就是grep之后打出某一段的日志再sort | uniq一下统计出错类型,最多再加个-c统计下个数。那天看一同事用的极6,所以查查资料学习学习。

先说说我会的
1. 查看不同的UID并统计个数
以ps -ef 为例
ps -ef | awk '{print $1}' | sort | uniq -c
当然也是支持printf那种格式化输出的,写法和C语言一样

  1. 过滤出/掉特定的值,比如我们这里取uid为501的值但保留表头
    ps -ef | awk '$1==501 || NR==1'
    当然后面也可以跟{}和print 连用

下面是一些进阶用法
1. 分隔符 -F
以.bash_profile为例子
export xxx=yyy这种格式,我们来取yyy
cat ~/.bash_profile | awk '{print $2}' | awk -F'=' '{print $2}'
2. 字符串匹配
还是以ps -ef为例
找出CMD里带有System的进程
ps -ef | awk '$8 ~ /System/ || NR==1 {print $1,$8}'
取反用!~即可
3. 拆分文件
常有错误日志,按错误类型分类,直接重定向即可,当然你的日志要规范,此处$6是错误类型
`awk 'NR!=1{print > $6}' error.log
当然也是支持if,else这种语法的
4. 统计功能
统计每个用户的进程的占了多少内存
ps aux | awk 'NR!=1{a[$1]+=$6;} END { for(i in a) print i ", " a[i]"KB";}'
这里直接用上数组和循环了

猜你喜欢

转载自blog.csdn.net/weixin_41571449/article/details/80014073
awk