准备一份文档:adb shell ps > text.txtshell
1.截取文档中的某个字段blog
-F 指定分隔符,不加默认空格或tab分隔符,print打印自定义的内容须要用" "扩起来进程
awk -F ':'文档
adb shell ps|grep -v 'root'|awk {print "packageName:" $9}字符串
指定多个分隔符 awk -F [<|>] filename数学
指定汉字做为分隔符 awk -F字 filename;awk -F '(路|非)' filenamefor循环
2.匹配字符或字符串 字符串用//分隔awk
awk '/root/' text.txt 打印包含root的行变量
awk '$1~/root/' text.txt 打印包含非root的行file
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