歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux綜合 >> 學習Linux >> 如何使用 awk 的 ‘next’ 命令

如何使用 awk 的 ‘next’ 命令

日期:2017/3/6 9:16:01   编辑:學習Linux

如何使用 awk 的 ‘next’ 命令


如何使用 awk 的 ‘next’ 命令


導讀在 awk 系列文章中,我們來看一下next 命令 ,它告訴 awk 跳過你所提供的所有剩下的模式和表達式,直接處理下一個輸入行。next 命令幫助你阻止運行命令執行過程中多余的步驟。

如何使用 awk 的 ‘next’ 命令如何使用 awk 的 ‘next’ 命令
要明白它是如何工作的, 讓我們來分析一下 food_list.txt 它看起來像這樣:

Food List ItemsNo      Item_Name               Price           Quantity1       Mangoes                 $3.45              52       Apples                  $2.45              253       Pineapples              $4.45              554       Tomatoes                $3.45              255       Onions                  $1.45              156       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      Quantity1     Mangoes       $3.45       5    *2     Apples        $2.45      253     Pineapples    $4.45      554     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

如何使用 awk 的 ‘next’ 命令如何使用 awk 的 ‘next’ 命令

當輸入行用$4 <= 20 { printf "%s/t%s/n", $0,"*" ; next ; }命令打印以後,next命令將跳過第二個$4 > 20 { print $0 ;}表達式,繼續判斷下一個輸入行,而不是浪費時間繼續判斷一下是不是當前輸入行還大於 20。

next命令在編寫高效的命令腳本時候是非常重要的,它可以提高腳本速度。

原文來自:https://linux.cn/article-7609-1.html

轉載地址:http://www.linuxprobe.com/awk-next-use.html


http://xxxxxx/Linuxjc/1155950.html TechArticle

Copyright © Linux教程網 All Rights Reserved