您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何使用awk的比較操作符,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
對(duì)于使用 awk 命令的用戶來(lái)說(shuō),處理一行文本中的數(shù)字或者字符串時(shí),使用比較運(yùn)算符來(lái)過(guò)濾文本和字符串是十分方便的。下面的部分我們介紹"awk"的比較運(yùn)算符。
awk 中的比較運(yùn)算符是什么?
awk 中的比較運(yùn)算符用于比較字符串和或者數(shù)值,包括以下類型:
符號(hào) 作用
> 大于
< 小于
>= 大于等于
<= 小于等于
== 等于
!= 不等于
some_value ~ / pattern/ 如果 some_value 匹配模式 pattern,則返回 true
some_value !~ / pattern/ 如果 some_value 不匹配模式 pattern,則返回 true 現(xiàn)在我們通過(guò)例子來(lái)熟悉 awk 中各種不同的比較運(yùn)算符。
例子一,我們有一個(gè)文件名為 food_list.txt 的文件,里面包括不同食物的購(gòu)買列表。我想給食物數(shù)量小于或等于 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 中使用比較運(yùn)算符的通用語(yǔ)法如下:
# 表達(dá)式 { 動(dòng)作; }
為了實(shí)現(xiàn)剛才的目的,執(zhí)行下面的命令:
# 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 **
在剛才的例子中,發(fā)生如下兩件重要的事情:
第一個(gè)“表達(dá)式 {動(dòng)作;}”組合中, $3 <= 30 { printf “%s/t%s/n”, $0,”**” ; } 打印出數(shù)量小于等于30的行,并且在后面增加 (**) 。物品的數(shù)量是通過(guò) $3 這個(gè)域變量獲得的。 第二個(gè)“表達(dá)式 {動(dòng)作;}”組合中, $3 > 30 { print $0 ;} 原樣輸出數(shù)量小于等于 30 的行。
再舉一個(gè)例子:
# 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
在這個(gè)例子中,我們想通過(guò)在行的末尾增加 (TRUE) 來(lái)標(biāo)記數(shù)量小于等于20的行。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何使用awk的比較操作符”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。