awk簡單用法
準備一份文檔:adb shell ps > text.txt
1.截取文檔中的某個字段
-F 指定分隔符,不加默認空格或tab分隔符,print打印自定義的內容需要用" "擴起來
awk -F ‘:‘
adb shell ps|grep -v ‘root‘|awk {print "packageName:" $9}
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
awk簡單用法