温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么使用 awk 复合表达式

发布时间:2021-10-23 09:54:39 来源:亿速云 阅读:140 作者:小新 栏目:系统运维

这篇文章主要介绍了怎么使用 awk 复合表达式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一直以来在查对条件是否匹配时,我们使用的都是简单的表达式。那如果你想用超过一个表达式来查对特定的条件呢?

本文中,我们将看看如何在过滤文本和字符串时,结合多个表达式,即复合表达式,用以查对条件。

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

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

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

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

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

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

注意:切记要加括号。

表达式可以由比较操作符构成,具体可查看 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

我们只想打印出价格超过 $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     *

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

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

感谢你能够认真阅读完这篇文章,希望小编分享的“怎么使用 awk 复合表达式”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

awk
AI