您好,登錄后才能下訂單哦!
awk -F: '{print$1}' /etc/passwd
#顯示passwd 的用戶名
awk -F: '$NF=="/bin/bash"{print $1,$NF}' /etc/passwd
#顯示出shell為 "/bin/bash" 的用戶
awk 'BEGIN{print"開頭"}{print$0}END{print"結束"}' /etc/passwd
#BENGIN可以理解為頁頭,END理解為頁腳
df -h|awk -F% '/^\/dev/{print $1}'|awk '{if($5>=20)print $1,$5"%"}
#先匹配dev,應為dev開頭的才是真正掛載的找出磁盤空間大于20%的,思路先用%切成兩段,把第一段管道給后面,這是$5已經取出想要的值了,進行比較大于20就輸出
awk '{FS=":";OFS="---"}{print NR,$1,$2,$3}' /etc/passwd
#以:為定界,---為輸出定界符
awk -F":" '{if($1=="root")print$0}' /etc/passwd
#單if使用,第一個字段內容等于"root"就顯示。
awk -F":" '($1=="root"){print$0}' /etc/passwd
#另一種寫法,和上面一樣,不用帶if 用()就可以了
awk -F":" '{if($1=="root")next}{print$0}' /etc/passwd
#單if使用,第一個字段等于"root"就跳過,顯示后面的,和上面正好顯示相反的
#next 本次直接跳過,exit直接退出,但是有EOF還是要執行EOF的內容
awk -F: '{if(NR>=2&&NR<=10)print $1}' /etc/passwd
#and的用法,表示顯示第2到10行數據
awk -F: '{if(NR==2||NR==10)print $1}' /etc/passwd
#or的用法,表示顯示第2和第10行
awk -F: '{if(NR!=2)print $1}' /etc/passwd
#取反的用法,除了第二行,其他都顯示
awk -F: '{if($3<=500){print$1,$3,"系統用戶"}else{print$1,$3,"普通用戶"}}' /etc/passwd
#雙分支使用,以ID號為參數,大于500的輸出為系統用戶 ,其他輸出為普通用戶
實戰
df -h|awk -F% '/^\/dev/{print $1}'|awk '{if($5>=20)print $1,$5"%"}'
#功能,找出磁盤空間已用大于%20的,思路先用%切成兩段,把第一段管道給后面,這是$5已經取出想要的值了,進行比較大于20就輸出
awk -v x=$z -F" " NR==x'{print$0}' /etc/ansible/hosts
#awk 不能直接調用變量,需要用-v 聲明下變量,變量z是shell里面的,x是awk內部的,把z變量賦值給x,x就能在后面調用了,調用無需其他符號直接使用
echo "$*"|awk -v y=$y -F" " '{print $y}'
#在{prinf } 內存引用變量 ,必須用'' 單引號,雙引號不可以
AKW取反
echo "1 2 3 4" |awk -F" " '{$1="";print$0}'
#會顯示 2 3 4
echo "1 2 3 4" |awk -F" " '{$NF="";print$0}'
#顯示1 2 3
echo "10.1.1.1"|awk -F"." '{print NF}'
#查看有幾個字段數
echo "10.1.1.1"|awk -F"." '{print $NF}'
#查看最后一個字段的內容
awk '{FS=":";OFS="***"}{print NR,$1,$2,$3}' /etc/passwd
#以:分隔符,以"***"為顯示分隔符,顯示行號及$1 $2 $3
awk -F":" 'BEGIN{print"用戶""\t""ID"}{if($3<5)print$1"\t"$3}END{print"結束"}' /etc/passwd
#BENGIN和END可以理解為頁眉頁腳,美化輸出的
BEGIN的幾種循環寫法
awk 'BEGIN{for(i=0;i<=5;i++){print i}}'
awk -v i=0 'BEGIN{ while(i<=5){print i;i++}}'
awk 'BEGIN{i=0;while(i<=5){print i;i++}}'
awk 'BEGIN{i=7;do{print"測試"i;i++}while(i<5)}'
幾種循環的寫法,最后一種do是無論條件滿足否都會執行一次
一種高級用法
cat /etc/fstab |awk '/^UUID/||/^\/dev/{fs[$3]++}END{for(i in fs){print i,fs[i]}}'
黃色表示匹配出UUID或者 /dev開頭的行,紅色以$3的字段名為數組的索引每次對數組的值加1,數組的值無需初始化默認為0,藍色以數組的索引作為循環列表,顯示i i就是$3的里的內容,fs[i]是每次累加最后統計的和
awk -F: '{printf "%-20s %-3s %-1s\n",$1,$2,$3}' /etc/passwd
#$1對應"%-20s",$2對應"%-1s",$3對應"%-1s\n",
"% s" %和s是固定格式 -表示左對齊默認右對齊 20表示顯示字符不足20個用空格補全到20個字符
其他例子
printf "%s %s %s %s %s\n" a b c d e f g h i j
表示每個%s 對應這一個值輸出,像這個格式位有5個,有10個值,正好輸出會輸出成兩排
printf "%-10s %-8s %-4.3f\n" 郭芙 女 47.9876
%-10s 指一個寬度為10個字符(-表示左對齊,沒有則表示右對齊),任何字符都會被顯示在10個字符寬的字符內,如果不足則自動以空格填充,超過也會將內容全部顯示出來。
%-4.2f 指格式化為小數,其中.2指保留2位小數。
awk -F":" '/\/bin\/bash/{print $1}' /etc/passwd
#表示只匹配到"bin/bash"的,才處理
awk -F":" '!/\/bin\/bash/{print $1 $7}' /etc/passwd
#加個!號取反,匹配到"bin/bash"的不處理,其他都處理
awk -F":" '/\/bin\/bash/||/\/bin\/csh/{print $1 $7}' /etc/passwd
#表示匹配到"/bin/bash","/bin/csh"才處理
awk -F":" '/\/bin\/bash|\/bin\/csh/{print $1 $7}' /etc/passwd
#和上面一樣,只不過上面是||的寫法,這個是|的寫法
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。