對於 使用 awk 命令的用戶來講,處理一行文本中的數字或者字符串時,使用比較運算符來過濾文本和字符串是十分方便的。linux
在 awk 系列的此部分中,咱們將探討一下如何使用比較運算符來過濾文本或者字符串。若是你是程序員,那麼你應該已經熟悉了比較運算符;對於其它人,下面的部分將介紹比較運算符。git
awk 中的比較運算符用於比較字符串和或者數值,包括如下類型:程序員
>
– 大於<
– 小於>=
– 大於等於<=
– 小於等於==
– 等於!=
– 不等於some_value ~ / pattern/
– 若是 some_value 匹配模式 pattern,則返回 truesome_value !~ / pattern/
– 若是 some_value 不匹配模式 pattern,則返回 true如今咱們經過例子來熟悉 awk 中各類不一樣的比較運算符。github
在這個例子中,咱們有一個文件名爲 food_list.txt 的文件,裏面包括不一樣食物的購買列表。我想給食物數量小於或等於 30 的物品所在行的後面加上(**)
app
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 中使用比較運算符的通用語法以下:ide
# 表達式 { 動做; }
爲了實現剛纔的目的,執行下面的命令:code
# awk '$3 <= 30 { printf "%s\t%s\n", $0,"**" ; } $3 > 30 { print $0 ;}' 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 「%s\t%s\n」, $0,」**」 ; }
打印出數量小於等於30的行,而且在後面增長(**)
。物品的數量是經過 $3
這個域變量得到的。$3 > 30 { print $0 ;}
原樣輸出數量小於等於 30
的行。再舉一個例子:get
# awk '$3 <= 20 { printf "%s\t%s\n", $0,"TRUE" ; } $3 > 20 { print $0 ;} ' 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的行。it
這是一篇對 awk 中的比較運算符介紹性的指引,所以你須要嘗試其餘選項,發現更多使用方法。
若是你遇到或者想到任何問題,請在下面評論區留下評論。請記得閱讀 awk 系列下一部分的文章,那裏我將介紹組合表達式。
via: http://www.tecmint.com/comparison-operators-in-awk/
做者:Aaron Kili
譯者:chunyang-wen
校對:wxy