对于 使用 awk 命令的用户来讲,处理一行文本中的数字或者字符串时,使用比较运算符来过滤文本和字符串是十分方便的。linux
在 awk 系列的此部分中,咱们将探讨一下如何使用比较运算符来过滤文本或者字符串。若是你是程序员,那么你应该已经熟悉了比较运算符;对于其它人,下面的部分将介绍比较运算符。git
awk 中的比较运算符用于比较字符串和或者数值,包括如下类型:程序员
>
– 大于<
– 小于>=
– 大于等于<=
– 小于等于==
– 等于!=
– 不等于some_value ~ / pattern/
– 若是 some_value 匹配模式 pattern,则返回 truesome_value !~ / pattern/
– 若是 some_value 不匹配模式 pattern,则返回 true如今咱们经过例子来熟悉 awk 中各类不一样的比较运算符。github
在这个例子中,咱们有一个文件名为 food_list.txt 的文件,里面包括不一样食物的购买列表。我想给食物数量小于或等于 30 的物品所在行的后面加上(**)
app
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 中使用比较运算符的通用语法以下:ide
# 表达式 { 动做; }
为了实现刚才的目的,执行下面的命令:code
# awk '$3 <= 30 { printf "%s\t%s\n", $0,"**" ; } $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 **
在刚才的例子中,发生以下两件重要的事情:字符串
$3 <= 30 { printf “%s\t%s\n”, $0,”**” ; }
打印出数量小于等于30的行,而且在后面增长(**)
。物品的数量是经过 $3
这个域变量得到的。$3 > 30 { print $0 ;}
原样输出数量小于等于 30
的行。再举一个例子:get
# awk '$3 <= 20 { printf "%s\t%s\n", $0,"TRUE" ; } $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的行。it
这是一篇对 awk 中的比较运算符介绍性的指引,所以你须要尝试其余选项,发现更多使用方法。
若是你遇到或者想到任何问题,请在下面评论区留下评论。请记得阅读 awk 系列下一部分的文章,那里我将介绍组合表达式。
via: http://www.tecmint.com/comparison-operators-in-awk/
做者:Aaron Kili
译者:chunyang-wen
校对:wxy