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 命令

awk -F: \\\’/bash$/{print | "wc -l"}\\\’ /etc/passwd
//調(diào)用wc -l 命令統(tǒng)計使用bash 的用戶個數(shù),等同于 grep -c "bash$" /etc/passwd

awk \\\’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)前的主機名

sort

sort 是一個以行為單位對文件內(nèi)容進(jìn)行排序的工具,也可以根據(jù)不同的數(shù)據(jù)類型來排序。例如數(shù)據(jù)和字符的牌局就不一樣。sort 命令的語法為“sort [選項] 參數(shù)”,其中常用的選項包括以下幾種。

?-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

Uniq 工具在 Linux 系統(tǒng)中通常與 sort 命令結(jié)合使用,用于報告或者忽略文件中的重復(fù)行。具體的命令語法格式為:uniq [選項] 參數(shù)。其中常用選項包括以下幾種。
?

-c:進(jìn)行計數(shù);
-d:僅顯示重復(fù)行;

-u:僅顯示出現(xiàn)一次的行;

以下文本為例

更多關(guān)于云服務(wù)器,域名注冊,虛擬主機的問題,請訪問西部數(shù)碼官網(wǎng):m.bingfeng168.cn

贊(0)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享網(wǎng)絡(luò)內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-62778877-8306;郵箱:fanjiao@west.cn。本站原創(chuàng)內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明出處:西部數(shù)碼知識庫 » 正則表達(dá)式工具(下)

登錄

找回密碼

注冊