系統(tǒng)運(yùn)維 awk
1.awk 常見用法
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供商城網(wǎng)站建設(shè)、商城做網(wǎng)站、商城網(wǎng)站設(shè)計、商城網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、商城企業(yè)網(wǎng)站模板建站服務(wù),10多年商城做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。通常情況下 awk 所使用的命令格式如下所示,其中,單引號加上大括號“{}”用于設(shè)置對數(shù)據(jù)進(jìn)行的處理動作。awk 可以直接處理目標(biāo)文件,也可以通過“-f”讀取腳本對目標(biāo)文件進(jìn)行處理。且默認(rèn)情況下字段的分隔符為空格或者 tab 鍵。awk 執(zhí)行結(jié)果可以通過 print 的功能將字段數(shù)據(jù)打印顯示。在使用 awk 命令的過程中,可以使用邏輯操作符“&&”,表示“與”, “||”表示“或”,“!”表示“非”;還可以進(jìn)行簡單的數(shù)學(xué)運(yùn)算,如+、-、*、/、%、^分別 表示加、減、乘、除、取余和乘方。
awk 選項 \'模式或條件 {編輯指令}\' 文件 1 文件 2 //過濾并輸出文件符條件的內(nèi)容
awk -f 腳本文件 文件 1 文件 2 //從腳本中調(diào)用編輯指令,過濾并輸出內(nèi)容
2 內(nèi)建變量
FS:指定每行文本的字段分隔符,默認(rèn)為空格或制表位。
NF:當(dāng)前處理的行的字段個數(shù)。
NR:當(dāng)前處理的行的行號(序數(shù))。
$0:當(dāng)前處理的行的整行內(nèi)容。
$n:當(dāng)前處理行的第 n 個字段(第 n 列)。
FILENAME:被處理的文件名。
RS:數(shù)據(jù)記錄分隔,默認(rèn)為\\n,即每行為一條記錄。
3 用法示例
1)按行輸出文本
awk \'{print}\' test.txt //輸出所有內(nèi)容,等同于 cat test.txt
awk \'{print $0}\' test.txt //輸出所有內(nèi)容,等同于 cat test.txt
awk \'NR==1,NR==3{print}\' test.txt //輸出第 1~3 行內(nèi)容
awk \'(NR>=1)&&(NR<=3){print}\' test.txt //輸出第 1~3 行內(nèi)容
awk \'NR==1||NR==3{print}\' test.txt //輸出第 1 行、第 3 行內(nèi)容
awk \'(NR%2)==1{print}\' test.txt //輸出所有奇數(shù)行的內(nèi)容
awk \'(NR%2)==0{print}\' test.txt //輸出所有偶數(shù)行的內(nèi)容
awk \'/^root/{print}\' /etc/passwd //輸出以root 開頭的行awk \'/nologin$/{print}\' /etc/passwd //輸出以 nologin 結(jié)尾的行
awk \'BEGIN {x=0} ; /\\/bin\\/bash$/{x++};END {print x}\' /etc/passwd
//統(tǒng)計以/bin/bash 結(jié)尾的行數(shù),等同于 grep -c "/bin/bash$" /etc/passwd awk\'BEGIN{RS=""};END{print NR}\' /etc/squid/squid.conf
//統(tǒng)計以空行分隔的文本段落數(shù)
2)按字段輸出文本
awk \'{print $3}\' test.txt //輸出每行中(以空格或制表位分隔)的第 3 個字段
awk \'{print $1,$3}\' test.txt //輸出每行中的第 1、3 個字段
awk -F ":" \'$2==""{print}\' /etc/shadow //輸出密碼為空的用戶的shadow 記錄awk \'BEGIN {FS=":"}; $2==""{print}\' /etc/shadow
//輸出密碼為空的用戶的shadow 記錄awk -F ":" \'$7~"/bash"{print $1}\' /etc/passwd
//輸出以冒號分隔且第 7 個字段中包含/bash 的行的第 1 個字段awk \'($1~"nfs")&&(NF==8){print $1,$2}\' /etc/services
//輸出包含 8 個字段且第 1 個字段中包含 nfs 的行的第 1、2 個字段awk -F ":" \'($7!="/bin/bash")&&($7!="/sbin/nologin"){print}\'/etc/passwd
//輸出第 7 個字段既不為/bin/bash 也不為/sbin/nologin 的所有行
3)通過管道、雙引號調(diào)用 Shell 命令
sortawk -F: \'/bash$/{print | "wc -l"}\' /etc/passwd
//調(diào)用wc -l 命令統(tǒng)計使用bash 的用戶個數(shù),等同于 grep -c "bash$" /etc/passwdawk \'BEGIN {while ("w" | getline) n++ ; {print n-2}}\'
//調(diào)用w 命令,并用來統(tǒng)計在線用戶數(shù)awk \'BEGIN { "hostname" | getline ; print $0}\'
//調(diào)用hostname,并輸出當(dāng)前的主機(jī)名
sort 是一個以行為單位對文件內(nèi)容進(jìn)行排序的工具,也可以根據(jù)不同的數(shù)據(jù)類型來排序。例如數(shù)據(jù)和字符的牌局就不一樣。sort 命令的語法為“sort [選項] 參數(shù)”,其中常用的選項包括以下幾種。
uniq?-f:忽略大小寫;
?-b:忽略每行前面的空格;
?-M:按照月份進(jìn)行排序;
?-n:按照數(shù)字進(jìn)行排序;
?-r:反向排序;
?-u:等同于 uniq,表示相同的數(shù)據(jù)僅顯示一行;
?-t:指定分隔符,默認(rèn)使用[Tab]鍵分隔;
?-o <輸出文件>:將排序后的結(jié)果轉(zhuǎn)存至指定文件;
?-k:指定排序區(qū)域。
Uniq 工具在 Linux 系統(tǒng)中通常與 sort 命令結(jié)合使用,用于報告或者忽略文件中的重復(fù)行。具體的命令語法格式為:uniq [選項] 參數(shù)。其中常用選項包括以下幾種。
?
-c:進(jìn)行計數(shù);
-d:僅顯示重復(fù)行;-u:僅顯示出現(xiàn)一次的行;
以下文本為例