十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
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 中的比较运算符介绍性的指引,因此你需要尝试其他选项,发现更多使用方法。