在 Linux系統(tǒng)中,awk 是一個(gè)功能強(qiáng)大的編輯工具,逐行讀取輸入文本,并根據(jù)指定的匹配模式進(jìn)行查找,對(duì)符合條件的內(nèi)容進(jìn)行格式化輸出或者過(guò)濾處理,可以在無(wú)交互的情況下實(shí)現(xiàn)相當(dāng)復(fù)雜的文本操作,被廣泛應(yīng)用于 Shell 腳本,完成各種自動(dòng)化配置任務(wù)。
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、敘州網(wǎng)絡(luò)推廣、重慶小程序開(kāi)發(fā)公司、敘州網(wǎng)絡(luò)營(yíng)銷、敘州企業(yè)策劃、敘州品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供敘州建站搭建服務(wù),24小時(shí)服務(wù)熱線:18982081108,官方網(wǎng)址:www.cdcxhl.com
一般來(lái)說(shuō) awk 所使用的命令格式如下所示,其中,單引號(hào)加上大括號(hào)“{}”用于設(shè)置對(duì)數(shù)據(jù)進(jìn)行的處理動(dòng)作。awk 可以直接處理目標(biāo)文件,也可以通過(guò)“-f”讀取腳本對(duì)目標(biāo)文件進(jìn)行處理。
awk 選項(xiàng) '模式或條件 {編輯指令}' 文件 1 文件 2 ? //過(guò)濾并輸出文件符條件的內(nèi)容
awk -f 腳本文件 文件 1 文件 2 ? //從腳本中調(diào)用編輯指令,過(guò)濾并輸出內(nèi)容
awk 相對(duì)傾向于將一行分成多個(gè)“字段”然后再進(jìn)行處理,且默認(rèn)情況下字段的分隔符為空格或者 tab 鍵。awk 執(zhí)行結(jié)果可以通過(guò) print 的功能將字段數(shù)據(jù)打印顯示。在使用 awk 命令的過(guò)程中,可以使用邏輯操作符“&&”,表示“與”, “||”表示“或”,“!”表示“非”;還可以進(jìn)行簡(jiǎn)單的數(shù)學(xué)運(yùn)算,如+、-、*、/、%、^分別 表示加、減、乘、除、取余和乘方。
在 Linux 系統(tǒng)中/etc/passwd 是一個(gè)非常典型的格式化文件,各字段間使用“:”作為分隔符隔開(kāi),Linux 系統(tǒng)中的大部分日志文件也是格式化文件,從這些文件中提取相關(guān)信息是運(yùn)維的日常工作內(nèi)容之一。若需要查找出/etc/passwd 的用戶名、用戶 ID、組 ID 等列, 執(zhí)行以下 awk 命令即可。
[root@192 ~]# awk -F ':' '{print $1,$3,$5}' /etc/passwd
root 0 root
bin 1 bin
daemon 2 daemon
adm 3 adm
lp 4 lp
sync 5 sync
shutdown 6 shutdown
awk 從輸入文件或者標(biāo)準(zhǔn)輸入中讀入信息,與 sed 一樣,信息的讀入也是逐行讀取的。不同的是 awk 將文本文件中的一行視為一個(gè)記錄,而將一行中的某一部分(列)作為記錄中的一個(gè)字段(域)。為了操作這些不同的字段,awk 借用 shell 中類似于位置變量的方法, 用$1、$2、$3?順序地表示行(記錄)中的不同字段。另外 awk 用$0 表示整個(gè)行(記錄)。不同的字段之間是通過(guò)指定的字符分隔。awk 默認(rèn)的分隔符是空格。awk 允許在命令行中用“-F 分隔符”的形式來(lái)指定分隔符。
FS:指定每行文本的字段分隔符,默認(rèn)為空格或制表位
NF:當(dāng)前處理的行的字段個(gè)數(shù)
NR:當(dāng)前處理的行的行號(hào)(序數(shù))
$0:當(dāng)前處理的行的整行內(nèi)容
$n:當(dāng)前處理行的第 n 個(gè)字段(第 n 列)
FILENAME:被處理的文件名
RS:數(shù)據(jù)記錄分隔,默認(rèn)為\n,即每行為一條記錄
awk '{print}' try.txt //輸出所有內(nèi)容,等同于 cat test.txt
awk '{print $0}' try.txt //輸出所有內(nèi)容,等同于 cat test.txt
awk 'NR==1,NR==3{print}' try.txt //輸出第 1~3 行內(nèi)容
awk '(NR>=1)&&(NR<=3){print}' try.txt //輸出第 1~3 行內(nèi)容
awk 'NR==1||NR==3{print}' try.txt //輸出第 1 行、第 3 行內(nèi)容
awk '(NR%2)==1{print}' try.txt //輸出所有奇數(shù)行的內(nèi)容
awk '(NR%2)==0{print}' try.txt //輸出所有偶數(shù)行的內(nèi)容
awk '/^root/{print}' /etc/passwd //輸出以root 開(kāi)頭的行
awk '/nologin$/{print}' /etc/passwd //輸出以 nologin 結(jié)尾的行
awk 'BEGIN {x=0} ; /\/bin\/bash$/{x++};END {print x}' /etc/passwd //統(tǒng)計(jì)以/bin/bash 結(jié)尾的行數(shù),等同于 grep -c "/bin/bash$" /etc/passwd
awk 'BEGIN{RS=""};END{print NR}' /etc/squid/squid.conf //統(tǒng)計(jì)以空行分隔的文本段落數(shù)
[root@192 opt]# awk '(NR%2)==1{print}' try.txt //輸出奇數(shù)行內(nèi)容
1
3
5
7
9
[root@192 opt]# awk '(NR%2)==0{print}' try.txt //輸出偶數(shù)行內(nèi)容
2
4
6
8
0
awk '{print $3}' test.txt //輸出每行中(以空格或制表位分隔)的第 3 個(gè)字段
awk '{print $1,$3}' test.txt //輸出每行中的第 1、3 個(gè)字段
awk -F ":" '$2==""{print}' /etc/shadow //輸出密碼為空的用戶的shadow 記錄
awk 'BEGIN {FS=":"}; $2==""{print}' /etc/shadow //輸出密碼為空的用戶的shadow 記錄
awk -F ":" '$7~"/bash"{print $1}' /etc/passwd //輸出以冒號(hào)分隔且第 7 個(gè)字段中包含/bash 的行的第 1 個(gè)字段
awk '($1~"nfs")&&(NF==8){print $1,$2}' /etc/services //輸出包含 8 個(gè)字段且第 1 個(gè)字段中包含 nfs 的行的第 1、2 個(gè)字段
awk -F ":" '($7!="/bin/bash")&&($7!="/sbin/nologin"){print}'/etc/passwd //輸出第 7 個(gè)字段既不為/bin/bash 也不為/sbin/nologin 的所有行
[root@192 opt]# awk -F ":" '$7~"/bash"{print $1}' /etc/passwd //輸出以冒號(hào)分隔且第 7 個(gè)字段中包含/bash 的行的第 1 個(gè)字段
root
czt
ccc
ccx
cax
max
etc
1.調(diào)用wc -l 命令統(tǒng)計(jì)使用bash 的用戶個(gè)數(shù),等同于 grep -c "bash$" /etc/passwd
[root@testID opt]# awk -F: '/bash$/{print | "wc -l"}' /etc/passwd
9
2.調(diào)用w 命令,并用來(lái)統(tǒng)計(jì)在線用戶數(shù)
[root@testID opt]# awk 'BEGIN {while ("w" | getline) n++ ;{print n-2}}'
5
3.調(diào)用hostname,并輸出當(dāng)前的主機(jī)名
[root@testID opt]# awk 'BEGIN {"hostname" | getline ; print $0}'
testID