Linux中國

awk 系列:如何使用 awk 比較操作符

對於 使用 awk 命令的用戶來說,處理一行文本中的數字或者字元串時,使用比較運算符來過濾文本和字元串是十分方便的。

awk 系列的此部分中,我們將探討一下如何使用比較運算符來過濾文本或者字元串。如果你是程序員,那麼你應該已經熟悉了比較運算符;對於其它人,下面的部分將介紹比較運算符。

awk 中的比較運算符是什麼?

awk 中的比較運算符用於比較字元串和或者數值,包括以下類型:

  • > – 大於
  • < – 小於
  • >= – 大於等於
  • <= – 小於等於
  • == – 等於
  • != – 不等於
  • some_value ~ / pattern/ – 如果 some_value 匹配模式 pattern,則返回 true
  • some_value !~ / pattern/ – 如果 some_value 不匹配模式 pattern,則返回 true

現在我們通過例子來熟悉 awk 中各種不同的比較運算符。

在這個例子中,我們有一個文件名為 food_list.txt 的文件,裡面包括不同食物的購買列表。我想給食物數量小於或等於 30 的物品所在行的後面加上(**)

File – food_list.txt
No      Item_Name               Quantity        Price
1       Mangoes                    45           $3.45
2       Apples                     25           $2.45
3       Pineapples                 5            $4.45
4       Tomatoes                   25           $3.45
5       Onions                     15           $1.45
6       Bananas                    30           $3.45

Awk 中使用比較運算符的通用語法如下:

# 表達式 { 動作; }

為了實現剛才的目的,執行下面的命令:

# awk &apos;$3 <= 30 { printf "%st%sn", $0,"**" ; } $3 > 30 { print $0 ;}&apos; food_list.txt

No  Item_Name`      Quantity    Price
1   Mangoes            45       $3.45
2   Apples             25       $2.45   **
3   Pineapples         5        $4.45   **
4   Tomatoes           25       $3.45   **
5   Onions             15       $1.45   **
6   Bananas            30       $3.45   **

在剛才的例子中,發生如下兩件重要的事情:

  • 第一個「表達式 {動作;}」組合中, $3 <= 30 { printf 「%st%sn」, $0,」**」 ; } 列印出數量小於等於30的行,並且在後面增加(**)。物品的數量是通過 $3 這個域變數獲得的。
  • 第二個「表達式 {動作;}」組合中, $3 > 30 { print $0 ;} 原樣輸出數量小於等於 30 的行。

再舉一個例子:

# awk &apos;$3 <= 20 { printf "%st%sn", $0,"TRUE" ; } $3 > 20  { print $0 ;} &apos; food_list.txt 

No    Item_Name     Quantity    Price
1     Mangoes          45       $3.45
2     Apples           25       $2.45
3     Pineapples        5       $4.45 TRUE
4     Tomatoes         25       $3.45
5     Onions           15       $1.45 TRUE
6     Bananas          30       $3.45

在這個例子中,我們想通過在行的末尾增加 (TRUE) 來標記數量小於等於20的行。

總結

這是一篇對 awk 中的比較運算符介紹性的指引,因此你需要嘗試其他選項,發現更多使用方法。

如果你遇到或者想到任何問題,請在下面評論區留下評論。請記得閱讀 awk 系列下一部分的文章,那裡我將介紹組合表達式。

via: http://www.tecmint.com/comparison-operators-in-awk/

作者:Aaron Kili 譯者:chunyang-wen 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國