簡介
awk是一個強大的文本分析工具,相對於grep的查找,sed的編輯,awk在其對數據分析並生成報告時,顯得尤爲強大。簡單來說awk就是把文件逐行讀入,以空格爲默認分割符將每行切片,切開的部分再進行各種分析處理。
使用方法:
awk [option] 'pattern1{action1}pattern2{action2}' {filenames}
儘管操作可能會很複雜,但語法總是這樣,其中pattern表示awk在數據中查找的內容,而action是在找到匹配內容時所執行的一系列命令。
awk內置的三個變量
NF:表示當前的所有字段$NF表示最後一個字段
FS:默認以空格符爲分割符
NR:awk讀取到了哪一行
awk基礎用法
1、regexp:正則表達式,格式爲/regular expreesion/
awk -F : '$3>=500{printf $1 "\n" $3 "\n"}' /etc/passwd
2、expression:表達式,其只非0或爲非空字符時滿足條件,例如~表示匹配(類似grep查找行匹配)
awk -F : '$7!~"bash$"{printf $7 "\n"}' /etc/passwd
3、ranges:指定匹配範圍,格式爲pat1,pat2
awk -F : '$3 == 0,$7~"nologin$"{printf $1 "\t" $7 "\n"}' /etc/passwd
4、BEGIN/END:特殊模式,
awk -F : 'BEGIN{printf "Username shell\n"}$3 == 0,$7~"nologin$"{printf $1 "\t" $7 "\n"}' /etc/passwd
5、空模式:表示沒有任意匹配選項