標籤:awk
簡介
awk是一個強大的文本分析工具,相對於grep的尋找,sed的編輯,awk在其對資料分析並產生報告時,顯得尤為強大。簡單來說awk就是把檔案逐行讀入,以空格為預設分割符將每行切片,切開的部分再進行各種分析處理。
使用方法:
awk [option] ‘pattern1{action1}pattern2{action2}‘ {filenames}
儘管操作可能會很複雜,但文法總是這樣,其中pattern表示awk在資料中尋找的內容,而action是在找到匹配內容時所執行的一系列命令。
awk內建的三個變數
NF:表示當前的所有欄位$NF表示最後一個欄位
FS:預設以空格符為分割符
NR:awk讀取到了哪一行
awk基礎用法
1、regexp:Regex,格式為/regular expreesion/
awk -F : ‘$3>=500{printf $1 "\n" $3 "\n"}‘ /etc/passwd
2、expression:運算式,其只非0或為非Null 字元時滿足條件,例如~表示匹配(類似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、空模式:表示沒有任意匹配選項
本文出自 “常想一二” 部落格,請務必保留此出處http://250919938.blog.51cto.com/962010/1918868
shell之awk