您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何使用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
上面的命令實際運行如下:
1.它用$4 <= 20表達式檢查每個輸入行的第四列(數量(Quantity))是否小于或者等于 20,如果滿足條件,它將在末尾打一個星號 (*)。
2.它用$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
當輸入行用$4 <= 20 { printf "%s/t%s/n", $0,"*" ; next ; }命令打印以后,next命令將跳過第二個$4 > 20 { print $0 ;}表達式,繼續判斷下一個輸入行,而不是浪費時間繼續判斷一下是不是當前輸入行還大于 20。
next命令在編寫高效的命令腳本時候是非常重要的,它可以提高腳本速度。
關于“如何使用awk的next命令”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。