最簡單地說, AWK 是一種用於處理文本的編程語言工具。AWK 在很多方面類似於 shell 編程語言,儘管 AWK 具有完全屬於其本身的語法。它的設計思想來源於 SNOBOL4 、sed 、Marc Rochkind設計的有效性語言、語言工具 yacc 和 lex ,當然還從 C 語言中獲取了一些優秀的思想。在最初創造 AWK 時,其目的是用於文本處理,並且這種語言的基礎是,只要在輸入數據中有模式匹配,就執行一系列指令。該實用工具掃描文件中的每一行,查找與命令行中所給定 內容相匹配的模式。如果發現匹配內容,則進行下一個編程步驟。如果找不到匹配內容,則繼續處理下一行
awk正則表達式
awk '{print NR,NF,FILENAME}' file ###統計行列並在每一行,NR:行號 NF:列 FILENAME:文件名
awk 'BEGIN{print "name"}' file ###初始化代碼塊(先處理,在處理其他),只能出現一次
awk 'END{print WESTOS}' file ###結束代碼塊(處理完結果後在處理),只能出現一次
awk -F ":" '/\<bash$/{print $1}' file ##找出含有bash關鍵字的行並以分號爲分隔符,打印出第1列,F:指定分隔符
awk -F "[: ]+" 'print $1' file ###以分號和空格爲分隔符,打印出第1列
awk 'BEGIN{a=1;print a+1}' file ###先給a賦值在進行加法
awk '/bash\>/{a++}END{print a}' file ###找出可登陸的用戶,並統計出個數
awk -F ":" '/^root/{print}' file ###找出以root開頭的並打印出來
awk -F ":" '/^a|nologin$/{print $1,$7}' file ###找出以a開頭的或者nologin結尾的,打印出第1,7列
awk -F ":" '$6~/bin$/{print $1,$7}' file ###以冒號爲分隔符,找出第6列爲bin結束的行,打印出其第1,7列
awk -F ":" '$6!~/bin$/{print $1,$7}' file ###以冒號爲分隔符,找出第6列不是bin結束的行,打印出其第1,7列
awk 'NR==2,NR==5{print}' file ###顯示出2,5行
awk '/a/,/b/{print}' file ###匹配出有a字符的行到有b字符的行,並打印出來
awk的應用
顯示當前系統可登陸用戶的name和id
awk -F ":" 'BEGIN{print "name id"}/\<bash$/{print $1" "$3}' /etc/passwd
統計行數可登陸行數
awk 'BEGIN{n=0}/\<bash$/{n++}END{print n}' /etc/passwd
能夠登陸且家目錄不在home下的用戶
awk -F ":" '/\<bash$/&&$6!~/^\/home/{print $1}' /etc/passwd
顯示文本中3-5行的內容
awk -F ":" 'NR>=3&&NR<=5{print}' /etc/passwd
顯示文本中6和8的內容
awk -F ":" 'NR==6||NR==8{print}' /etc/passwd
抓取ip地址
ifconfig eth0 |awk 'NR==2{print $2}'
求和1+2..+100
seq 100 >westos
awk '$1<=100;a++;sum=sum+a;{print sum}' westos|tail -1
awk '$1<=100{a++;sum+=a}END{print sum}' westos