準備一份文檔: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