awk是Unix环境下一种非常好的语言,适合于文本处理和报表生成,在进行文本处理时使用比较运算符来过滤文本和字符串是非常不错的选择,本篇文章重点为大家讲解一下awk中的比较运算符。
awk 中的比较运算符用于比较字符串和或者数值,包括以下类型:
符号 | 作用 |
---|---|
> | 大于 |
小于 | |
>= | 大于等于 |
小于等于 | |
== | 等于 |
!= | 不等于 |
some_value ~ / pattern/ | 如果 some_value 匹配模式 pattern,则返回 true |
some_value !~ / pattern/ | 如果 some_value 不匹配模式 pattern,则返回 true |
现在我们通过例子来熟悉 awk 中各种不同的比较运算符。
例子一,我们有一个文件名为 food_list.txt 的文件,里面包括不同食物的购买列表。我想给食物数量小于或等于 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 中使用比较运算符的通用语法如下:
# 表达式 { 动作; }
为了实现刚才的目的,执行下面的命令:
# awk '$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 **
在刚才的例子中,发生如下两件重要的事情:
再举一个例子:
# awk '$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的行。
这是一篇对 awk 中的比较运算符介绍性的指引,因此你需要尝试其他选项,发现更多使用方法。
分享名称:详解awk比较运算符使用方法
标题路径:http://www.csdahua.cn/qtweb/news1/313551.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网