awk简单用法
准备一份文档:adb shell ps > text.txt
1.截取文档中的某个字段
-F 指定分隔符,不加默认空格或tab分隔符,print打印自定义的内容需要用" "扩起来
awk -F ':'
adb shell ps|grep -v 'root'|awk {print "packageName:" $9}
指定多个分隔符 awk -F [<|>] filename
指定汉字作为分隔符 awk -F字 filename;awk -F '(路|非)' filename
2.匹配字符或字符串 字符串用//分隔
awk '/root/' text.txt 打印包含root的行
awk '$1~/root/' text.txt 打印包含非root的行
awk '/root/ {print $1} /system/ {print $1}' text.txt 打印包含root和system的行的第3列
判断上个命令执行成功,awk '/root/ {print $1} /system/ {print $1}' text.txt|grep -Ev 'root|system'
awk '$1~/root/ {print $1}' text.txt
3.条件操作符
== != > < >= <= && ||
awk可以用逻辑运算符号判断,但是awk会将所有内容视为字符,而非数字,因此此处的< > <= <=不是指数学关系
awk '$1=="100"' text.txt 精确匹配
awk '$1>="100"' text.txt
!= 即为不匹配
awk '$2!="100" {print $2}' text.txt|grep 100 发现没有100的进程
awk '$2=="100" || $2=="44"' text.txt
awk '$2<="44" && $2 >='100'' ' text.txt
4.awk内置变量
NF:用分隔符分隔后一共有多少段,$NF会打印最后一个字段
NR:行数
RS:行记录分隔符
FS:记录分隔符
BEGIN END
awk '{print NF, $NF}' text.txt|head -n 5
awk '{print NR}' text.txt 只打印行数,不打印内容
awk 'NR<5 ' text.txt 打印前4行
5.awk中的数学运算
将某个字段改成指定的字符串
awk '{$7=$3+$4;print{$3,$4,$7}}' text.txt
计算某个段的总和
awk '{(tot+=$3)};END {print tot}' text.txt
在awk中可以使用if判断,for循环
awk '{if ($1=="root") print $0}' text.txt