shell之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:正則表達式,格式爲/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、空模式:表示沒有任意匹配選項


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章