提高文本處理效率:精通 awk 命令中的 $NF
在AWK編程語言中,$NF是一個特定的變量,用于引用當前處理記錄中的最后一個字段值。這里的NF是AWK的一個內置變量,表示當前記錄所含字段的數量。通過使用$NF,可以直接獲取到與NF數值相對應的那個字段的具體內容。
示例使用
以下文件data.txt,為測試文件,內容如下:
Alice 30 Engineer
Bob 25 Designer
Charlie 35 Manager
(1) 您可以使用awk命令打印每一行的最后一個字段(職位名稱),執行如下命令:
awk '{ print $NF }' data.txt
執行上述命令后,輸出結果如下所示:
root@databases:~# awk '{ print $NF }' data.txt
Engineer
Designer
Manager
- 在data.txt文件的每一行中,awk根據空白(默認行為)將該行拆分為字段。
- 對于第一行,NF為3(代表Alice、30、Engineer),因此$NF指的是Engineer。
- 對于第二行,它指的是設計師,對于第三行,它指的是經理。
(2) 打印帶有行號的最后一個字段,可以執行如下命令:
awk '{ print NR ": " $NF }' data.txt
執行上述命令后,輸出結果如下所示:
root@databases:~# awk '{ print NR ": " $NF }' data.txt
1: Engineer
2: Designer
3: Manager
(3) 檢查最后一個字段是否與特定值匹配,可以執行如下命令:
awk '$NF == "Manager" { print $1 }' data.txt
執行上述命令后,輸出結果如下所示:
root@databases:~# awk '$NF == "Manager" { print $1 }' data.txt
Charlie
此命令打印最后一個字段為Manager的名稱。
(4) 對第二個字段進行總和,但僅打印最后一個字段,可以執行如下命令:
awk '{ sum += $2 } END { print "Total age is:", sum; print "Last field in last line is:", $NF }' data.txt
執行上述命令后,輸出結果如下所示:
root@databases:~# awk '{ sum += $2 } END { print "Total age is:", sum; print "Last field in last line is:", $NF }' data.txt
Total age is: 90
Last field in last line is: Manager
請注意,在該案例中,$NF指的是awk處理的最后一行的最后一個字段。
當您在處理每個人字段數量都不相同的數據時,$NF變量就顯得特別有幫助了。它能夠讓您靈活地獲取到最后一個字段的信息。