咱們將逐漸揭開 awk 功能的神祕面紗,在本節中,咱們將介紹 awk 內置(built-in)變量的概念。你能夠在 awk 中使用兩種類型的變量,它們是:用戶自定義(user-defined)變量(咱們在第八節中已經介紹了)和內置變量。html
awk 內置變量示例linux
awk 內置變量已經有預先定義的值了,但咱們也能夠謹慎地修改這些值,awk 內置變量包括:git
FILENAME
: 當前輸入文件名稱NR
: 當前輸入行編號(是指輸入行 1,2,3……等)NF
: 當前輸入行的字段編號OFS
: 輸出字段分隔符FS
: 輸入字段分隔符ORS
: 輸出記錄分隔符RS
: 輸入記錄分隔符讓咱們繼續演示一些使用上述 awk 內置變量的方法:github
想要讀取當前輸入文件的名稱,你能夠使用 FILENAME
內置變量,以下:shell
$ awk ' { print FILENAME } ' ~/domains.txt
awk FILENAME 變量dom
你會看到,每一行都會對應輸出一次文件名,那是你使用 FILENAME
內置變量時 awk 默認的行爲。ide
咱們能夠使用 NR
來統計一個輸入文件的行數(記錄),謹記,它也會計算空行,正如咱們將要在下面的例子中看到的那樣。學習
當咱們使用 cat 命令查看文件 domains.txt 時,會發現它有 14 行文本和 2 個空行:ui
$ cat ~/domains.txt
輸出文件內容code
$ awk ' END { print "Number of records in file is: ", NR } ' ~/domains.txt
awk 統計行數
想要統計一條記錄或一行中的字段數,咱們能夠像下面那樣使用 NR 內置變量:
$ cat ~/names.txt
列出文件內容
$ awk '{ "Record:",NR,"has",NF,"fields" ; }' ~/names.txt
awk 統計文件中的字段數
接下來,你也能夠使用 FS 內置變量指定一個輸入文件分隔符,它會定義 awk 如何將輸入行劃分紅字段。
FS 默認值爲「空格」和「製表符」,但咱們也能將 FS 值修改成任何字符來讓 awk 根據狀況切分輸入行。
有兩種方法能夠達到目的:
來看 Linux 系統上的 /etc/passwd
文件,該文件中的各字段是使用 :
分隔的,所以,當咱們想要過濾出某些字段時,能夠將 :
指定爲新的輸入字段分隔符,示例以下:
咱們能夠使用 -F
選項,以下:
$ awk -F':' '{ print $1, $4 ;}' /etc/passwd
awk 過濾密碼文件中的各字段
此外,咱們也能夠利用 FS 內置變量,以下:
$ awk ' BEGIN { FS=「:」 ; } { print $1, $4 ; } ' /etc/passwd
使用 awk 過濾文件中的各字段
使用 OFS 內置變量來指定一個用於輸出的字段分隔符,它會定義如何使用指定的字符分隔輸出字段,示例以下:
$ awk -F':' ' BEGIN { OFS="==>" ;} { print $1, $4 ;}' /etc/passwd
向文件中的字段添加分隔符
在本節中,咱們已經學習了使用含有預約義值的 awk 內置變量的理念。但咱們也可以修改這些值,雖然並不推薦這樣作,除非你明白本身在作什麼,而且充分理解(這些變量值)。
此後,咱們將繼續學習如何在 awk 命令操做中使用 shell 變量,因此,請繼續關注咱們。
via: http://www.tecmint.com/awk-built-in-variables-examples/
做者:Aaron Kili
譯者:ChrisLeeGit
校對:wxy