您好,登錄后才能下訂單哦!
這篇文章主要介紹Linux下awk內置變量怎么用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
awk 內置變量包括:
FILENAME : 當前輸入文件名稱
NR : 當前輸入行編號(是指輸入行 1,2,3……等)
NF : 當前輸入行的字段編號
OFS : 輸出字段分隔符
FS : 輸入字段分隔符
ORS : 輸出記錄分隔符
RS : 輸入記錄分隔符
FILENAME :
讓我們繼續演示一些使用上述 awk 內置變量的方法,想要讀取當前輸入文件的名稱,你可以使用 FILENAME 內置變量,如下:$ awk ' { print FILENAME } ' ~/domains.txt
你會看到,每一行都會對應輸出一次文件名,那是你使用 FILENAME 內置變量時 awk 默認的行為。我們可以使用 NR 來統計一個輸入文件的行數(記錄),謹記:它也會計算空行,正如我們將要在下面的例子中看到的那樣。 輸出文件內容 當我們使用 cat 命令查看文件 domains.txt 時,會發現它有 14 行文本和 2 個空行:$ cat ~/domains.txt
awk 統計行數:
$ awk ' END { print "Number of records in file is: ", NR } ' ~/domains.txt
awk 統計文件中的字段數:
$ awk '{ "Record:",NR,"has",NF,"fields" ; }' ~/names.txt
FS 內置變量:
你也可以使用 FS 內置變量指定一個輸入文件分隔符,它會定義 awk 如何將輸入行劃分成字段。FS 默認值為“空格”和“制表符”,但我們也能將 FS 值修改為任何字符來讓 awk 根據情況切分輸入行。有兩種方法可以達到目的:***種方法是使用 FS 內置變量;第二種方法是使用 awk 的 -F 選項。來看 Linux 系統上的 /etc/passwd 文件,該文件中的各字段是使用 冒號(:) 分隔的,因此,當我們想要過濾出某些字段時,可以將冒號(:) 指定為新的輸入字段分隔符, awk 過濾密碼文件中的各字段 . 我們可以使用 -F 選項,如下:$ awk -F':' '{ print $1, $4 ;}' /etc/passwd
此外,我們也可以利用 FS 內置變量,如下:$ awk ' BEGIN { FS=“:” ; } { print $1, $4 ; } ' /etc/passwd
使用 OFS 內置變量:
使用 OFS 內置變量來指定一個用于輸出的字段分隔符,它會定義如何使用指定的字符分隔輸出字 段 使用 awk輸出的分隔符: $ awk -F':' ' BEGIN { OFS="==>" ;} { print $1, $4 ;}' /etc/passwd
以上是“Linux下awk內置變量怎么用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。