在 awk 系列的第六節,我們來看一下next命令 ,它告訴 awk 跳過你所提供的所有剩下的模式和運算式,直接處理下一個輸入行。
next 命令協助你阻止運行命令執行過程中多餘的步驟。
要明白它是如何工作的, 讓我們來分析一下 food_list.txt 它看起來像這樣:
Food List Items
No Item_Name Price Quantity
1 Mangoes $3.45 5
2 Apples $2.45 25
3 Pineapples $4.45 55
4 Tomatoes $3.45 25
5 Onions $1.45 15
6 Bananas $3.45 30
運行下面的命令,它將在每個食物數量小於或者等於 20 的行後面標一個星號:
# awk '$4 <= 20 { printf "%s\t%s\n", $0,"*" ; } $4 > 20 { print $0 ;} ' food_list.txt
No Item_Name Price Quantity
1 Mangoes $3.45 5 *
2 Apples $2.45 25
3 Pineapples $4.45 55
4 Tomatoes $3.45 25
5 Onions $1.45 15 *
6 Bananas $3.45 30
上面的命令實際運行如下:
首先,它用$4 <= 20運算式檢查每個輸入行的第四列(數量(Quantity))是否小於或者等於 20,如果滿足條件,它將在末尾打一個星號 (*)。
接著,它用$4 > 20運算式檢查每個輸入行的第四列是否大於20,如果滿足條件,顯示出來。
但是這裡有一個問題, 當第一個運算式用{ printf "%s\t%s\n", $0,"**" ; }命令進行標註的時候在同樣的步驟第二個運算式也進行了判斷這樣就浪費了時間.
因此當我們已經用第一個運算式列印標誌行的時候就不再需要用第二個運算式$4 > 20再次列印。
要處理這個問題, 我們需要用到next 命令:
# awk '$4 <= 20 { printf "%s\t%s\n", $0,"*" ; next; } $4 > 20 { print $0 ;} ' food_list.txt
No Item_Name Price Quantity
1 Mangoes $3.45 5 *
2 Apples $2.45 25
3 Pineapples $4.45 55
4 Tomatoes $3.45 25
5 Onions $1.45 15 *
6 Bananas $3.45 30
當輸入行用$4 <= 20 { printf "%s\t%s\n", $0,"*" ; next ; }命令列印以後,next命令將跳過第二個$4 > 20 { print $0 ;}運算式,繼續判斷下一個輸入行,而不是浪費時間繼續判斷一下是不是當前輸入行還大於 20。
next命令在編寫高效的命令指令碼時候是非常重要的,它可以提高指令碼速度。本系列的下一部分我們將來學習如何使用 awk 來處理標準輸入(STDIN)。