awk 系列Part5:如何使用 awk 复合表达式
awk 系列:如何使用 awk 復(fù)合表達式
一直以來在查對條件是否匹配時,我們使用的都是簡單的表達式。那如果你想用超過一個表達式來查對特定的條件呢?
本文,我們將看看如何在過濾文本和字符串時,結(jié)合多個表達式,即復(fù)合表達式,用以查對條件。
awk 的復(fù)合表達式可由表示“與”的組合操作符 && 和表示“或”的 || 構(gòu)成。
復(fù)合表達式的常規(guī)寫法如下:
( 第一個表達式 ) && ( 第二個表達式 )這里只有當“第一個表達式” 和“第二個表達式”都是真值時整個表達式才為真。
( 第一個表達式 ) || ( 第二個表達式)這里只要“第一個表達式” 為真或“第二個表達式”為真,整個表達式就為真。
注意:切記要加括號。
表達式可以由比較操作符構(gòu)成,具體可查看 awk 系列的第四節(jié)。
現(xiàn)在讓我們通過一個例子來加深理解:
此例中,有一個文本文件 tecmint_deals.txt,文本中包含著一張隨機的 Tecmint 交易清單,其中包含了名稱、價格和種類。
TecMint Deal List No Name Price Type 1 Mac_OS_X_Cleanup_Suite $9.99 Software 2 Basics_Notebook $14.99 Lifestyle 3 Tactical_Pen $25.99 Lifestyle 4 Scapple $19.00 Unknown 5 Nano_Tool_Pack $11.99 Unknown 6 Ditto_Bluetooth_Altering_Device $33.00 Tech 7 Nano_Prowler_Mini_Drone $36.99 Tech我們只想打印出價格超過 $20 且其種類為 “Tech” 的物品,在其行末用 (*) 打上標記。
我們將要執(zhí)行以下命令。
# awk '($3 ~ /^\$[2-9][0-9]*\.[0-9][0-9]$/) && ($4=="Tech") { printf "%s\t%s\n",$0,"*"; } ' tecmint_deals.txt 6 Ditto_Bluetooth_Altering_Device $33.00 Tech * 7 Nano_Prowler_Mini_Drone $36.99 Tech *此例,在復(fù)合表達式中我們使用了兩個表達式:
- 表達式 1:($3 ~ /^\$[2-9][0-9]*\.[0-9][0-9]$/) ;查找交易價格超過 $20 的行,即只有當 $3 也就是價格滿足 /^\$[2-9][0-9]*\.[0-9][0-9]$/ 時值才為真值。
- 表達式 2:($4 == “Tech”) ;查找是否有種類為 “Tech”的交易,即只有當 $4 等于 “Tech” 時值才為真值。
切記,只有當 && 操作符的兩端狀態(tài),也就是兩個表達式都是真值的情況下,這一行才會被打上 (*) 標志。
總結(jié)
有些時候為了真正符合你的需求,就不得不用到復(fù)合表達式。當你掌握了比較和復(fù)合表達式操作符的用法之后,復(fù)雜的文本或字符串過濾條件也能輕松解決。
希望本向?qū)δ阌兴鶐椭?#xff0c;如果你有任何問題或者補充,可以在下方發(fā)表評論,你的問題將會得到相應(yīng)的解釋。
via: http://www.tecmint.com/combine-multiple-expressions-in-awk/
作者:Aaron Kili
譯者:martin2011qi
校對:wxy
本文由 LCTT 原創(chuàng)編譯,Linux中國 榮譽推出
轉(zhuǎn)載于:https://blog.51cto.com/wutengfei/2401621
總結(jié)
以上是生活随笔為你收集整理的awk 系列Part5:如何使用 awk 复合表达式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: layui 实现图片上传和预览
- 下一篇: Cobbler Web界面提示报错 “I