awk簡單用法

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

相關文章
相關標籤/搜索