awk 系列:如何使用 awk 比较操作符

对于 使用 awk 命令的用户来说,处理一行文本中的数字或者字符串时,使用比较运算符来过滤文本和字符串是十分方便的。

在 awk 系列的此部分中,我们将探讨一下如何使用比较运算符来过滤文本或者字符串。如果你是程序员,那么你应该已经熟悉了比较运算符;对于其它人,下面的部分将介绍比较运算符。

awk 中的比较运算符是什么?

awk 中的比较运算符用于比较字符串和或者数值,包括以下类型:

  • > – 大于
  • < – 小于
  • >= – 大于等于
  • <= – 小于等于
  • == – 等于
  • != – 不等于
  • some_value ~ / pattern/ – 如果 some_value 匹配模式 pattern,则返回 true
  • some_value !~ / pattern/ – 如果 some_value 不匹配模式 pattern,则返回 true

现在我们通过例子来熟悉 awk 中各种不同的比较运算符。

在这个例子中,我们有一个文件名为 food_list.txt 的文件,里面包括不同食物的购买列表。我想给食物数量小于或等于 30 的物品所在行的后面加上(**)

 
 
  1. File food_list.txt
  2. No Item_Name Quantity Price
  3. 1 Mangoes 45 $3.45
  4. 2 Apples 25 $2.45
  5. 3 Pineapples 5 $4.45
  6. 4 Tomatoes 25 $3.45
  7. 5 Onions 15 $1.45
  8. 6 Bananas 30 $3.45

Awk 中使用比较运算符的通用语法如下:

 
 
  1. # 表达式 { 动作; }

为了实现刚才的目的,执行下面的命令:

 
 
  1. # awk '$3 <= 30 { printf "%s\t%s\n", $0,"**" ; } $3 > 30 { print $0 ;}' food_list.txt
  2. No Item_Name` Quantity Price
  3. 1 Mangoes 45 $3.45
  4. 2 Apples 25 $2.45 **
  5. 3 Pineapples 5 $4.45 **
  6. 4 Tomatoes 25 $3.45 **
  7. 5 Onions 15 $1.45 **
  8. 6 Bananas 30 $3.45 **

在刚才的例子中,发生如下两件重要的事情:

  • 第一个“表达式 {动作;}”组合中, $3 <= 30 { printf “%s\t%s\n”, $0,”**” ; } 打印出数量小于等于30的行,并且在后面增加(**)。物品的数量是通过 $3 这个域变量获得的。
  • 第二个“表达式 {动作;}”组合中, $3 > 30 { print $0 ;} 原样输出数量小于等于 30 的行。

再举一个例子:

 
 
  1. # awk '$3 <= 20 { printf "%s\t%s\n", $0,"TRUE" ; } $3 > 20 { print $0 ;} ' food_list.txt
  2. No Item_Name Quantity Price
  3. 1 Mangoes 45 $3.45
  4. 2 Apples 25 $2.45
  5. 3 Pineapples 5 $4.45 TRUE
  6. 4 Tomatoes 25 $3.45
  7. 5 Onions 15 $1.45 TRUE
  8. 6 Bananas 30 $3.45

在这个例子中,我们想通过在行的末尾增加 (TRUE) 来标记数量小于等于20的行。

原文发布时间为:2016-07-22

本文来自云栖社区合作伙伴“Linux中国”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值