小編給大家分享一下LINUX中AWK內(nèi)建變量FS,NF,NR,RT,RS,ORS,OFS的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、成都小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了西藏免費(fèi)建站歡迎大家使用!
FS 指定字段un列分隔符(Font Space)
[~/AWK_learning]$ echo "111|222|333" | awk '{print $1}' 111|222|333 [~/AWK_learning]$ echo "111|222|333" | awk 'BEGIN{FS="|"}{print $1}' 111
OFS 指定輸出字段列分隔符(Output Font space)
[~/AWK_learning]$ echo "111 222 333" |awk 'BEGIN{OFS="|";}{print $1,$2,$3}' 111|222|333
RS指定行分隔符 默認(rèn)分隔符為\n(Row Space)
[~/AWK_learning]$ echo "111 222|333 444|555 666" | awk 'BEGIN{RS="|"}{print $0}' 111 222 333 444 555 666
ORS指定輸出行分隔符
[~/AWK_learning]$ awk 'BEGIN{ORS="|";}{print $0;}' test.txt 111 222|333 444|555 666
RT 代指分隔符
[~/AWK_learning]$ echo "111 222|333 444|555 666" | awk 'BEGIN{RS="|"}{print $0,RT}' 111 222 | 333 444 | 555 666 |
NF 每行字段總數(shù)(Number of Font)
[~/AWK_learning]$ cat test.txt 111 222 333 444 555 666 [~/AWK_learning]$ awk '{print NF}' test.txt 2 2 2 [~/AWK_learning]$ awk '{print $NF}' test.txt 222 444 666
NR 當(dāng)前行數(shù)(Number of Row)
[~/AWK_learning]$ cat test.txt 111 222 333 444 555 666 777 [~/AWK_learning]$ awk '{print NR}' test.txt 1 2 3 [~/AWK_learning]$ awk '{print $NR}' test.txt 111 444 777
下面我們?cè)趤?lái)看下,在內(nèi)建變量執(zhí)行中的相關(guān)問(wèn)題:
NR表示從awk開(kāi)始執(zhí)行后,按照記錄分隔符讀取的數(shù)據(jù)次數(shù),默認(rèn)的記錄分隔符為換行符,因此默認(rèn)的就是讀取的數(shù)據(jù)行數(shù),NR可以理解為Number of Record的縮寫(xiě)。
在awk處理多個(gè)輸入文件的時(shí)候,在處理完第一個(gè)文件后,NR并不會(huì)從1開(kāi)始,而是繼續(xù)累加,因此就出現(xiàn)了FNR,每當(dāng)處理一個(gè)新文件的時(shí)候,F(xiàn)NR就從1開(kāi)始計(jì)數(shù),F(xiàn)NR可以理解為File Number of Record。
NF表示目前的記錄被分割的字段的數(shù)目,NF可以理解為Number of Field。
下面以示例程序來(lái)進(jìn)行說(shuō)明,首先準(zhǔn)備兩個(gè)輸入文件class1和class2,記錄了兩個(gè)班級(jí)的成績(jī)信息,內(nèi)容分別如下所示:
CodingAnts@ubuntu:~/awk$ cat class1 zhaoyun 85 87 guanyu 87 88 liubei 90 86 CodingAnts@ubuntu:~/awk$ cat class2 caocao 92 87 90 guojia 99 96 92
現(xiàn)在要查看兩個(gè)班級(jí)的所有成績(jī)信息,并在每條信息前加上行號(hào),則可以使用下面的awk指令;
CodingAnts@ubuntu:~/awk$ awk '{print NR,$0}' class1 class2 1 zhaoyun 85 87 2 guanyu 87 88 3 liubei 90 86 4 caocao 92 87 90 5 guojia 99 96 92
這里的行號(hào)就是通過(guò)NR來(lái)實(shí)現(xiàn)的,awk每讀取一條記錄,NR的值便加一。如果要求每個(gè)班級(jí)的行號(hào)從頭開(kāi)始變化,則需要使用FNR來(lái)實(shí)現(xiàn),如下:
CodingAnts@ubuntu:~/awk$ awk '{print FNR,$0}' class1 class2 1 zhaoyun 85 87 2 guanyu 87 88 3 liubei 90 86 1 caocao 92 87 90 2 guojia 99 96 92
以上是“LINUX中AWK內(nèi)建變量FS,NF,NR,RT,RS,ORS,OFS的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!