linux复合指令,如何使用 awk 复合表达式

导读

一直以来在查对条件是否匹配时,我们使用的都是简单的表达式。那如果你想用超过一个表达式来查对特定的条件呢?本文中,我们将看看如何在过滤文本和字符串时,结合多个表达式,即复合表达式,用以查对条件。

eb1962aa58300a1ea861933e896d1ddd.png

awk 的复合表达式可由表示“与”的组合操作符“ &” 和表示“或”的“|| ”构成。

复合表达式的常规写法如下:

( 第一个表达式 ) & ( 第二个表达式 )

这里只有当“第一个表达式” 和“第二个表达式”都是真值时整个表达式才为真。

( 第一个表达式 ) || ( 第二个表达式)

这里只要“第一个表达式” 为真或“第二个表达式”为真,整个表达式就为真。

注意:切记要加括号。

表达式可以由比较操作符构成。

现在让我们通过一个例子来加深理解:

此例中,有一个文本文件 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

7e64a90268f300e7db47c769617bf75c.png

我们只想打印出价格超过 $20 且其种类为 “Tech” 的物品,在其行末用 (*) 打上标记。

我们将要执行以下命令。

# 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 *

df5222c639b9f8cfa139dd906f66d369.png

此例,在复合表达式中我们使用了两个表达式:

表达式 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” 时值才为真值。 切记,只有当 && 操作符的两端状态,也就是两个表达式都是真值的情况下,这一行才会被打上 (*) 标志。

总结

有些时候为了真正符合你的需求,就不得不用到复合表达式。当你掌握了比较和复合表达式操作符的用法之后,复杂的文本或字符串过滤条件也能轻松解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值