linux文本處理之awk

最簡單地說, 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







 

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