awk 中的比较运算符用于比较数字或字符串的值,它们包括以下内容:
>
- 大于<
- 小于>=
– 大于或等于<=
– 小于或等于==
- 等于!=
- 不等于some_value ~ / pattern/
– 如果 some_value 匹配模式,则为真some_value !~ / pattern/
– 如果 some_value 与模式不匹配,则为真现在我们已经了解了 awk 中的各种比较运算符,让我们通过一个例子更好地理解它们。
在这个例子中,我们有一个名为的文件
rumenz.txt
这是不同食品的购物清单,我想通过(**)
在每行末尾添加来标记数量小于或等于 20 的数据。
> cat rumenz.txt
No Item_Name Quantity Price
1 Mangoes 45 $45
2 Apples 25 $45
3 Pineapples 5 $45
4 Tomatoes 25 $45
5 Onions 15 $45
6 Bananas 30 $45
在 Awk 中使用比较运算符的一般语法是:
> expression { actions; }
查询数量少于30的数据
> awk '$3<30' rumenz.txt
2 Apples 25 $45
3 Pineapples 5 $45
4 Tomatoes 25 $45
5 Onions 15 $45
查询数量大于20但是小于30的数据
> awk '$3>20 && $3<30 ' rumenz.txt
2 Apples 25 $45
4 Tomatoes 25 $45
查询编号为3的数据
> awk '$1==3' rumenz.txt
3 Pineapples 5 $45
查询编号为3的商品名
> awk '$1==3{print $2 }' rumenz.txt
Pineapples
为了实现上述目标,我必须运行以下命令:
> awk '$3 <= 30 { printf "%s\t%s\n", $0,"**" ; } $3 > 30 { print $0 ;}' rumenz.txt
No Item_Name` Quantity Price
1 Mangoes 45 $45
2 Apples 25 $45 **
3 Pineapples 5 $45 **
4 Tomatoes 25 $45 **
5 Onions 15 $45 **
6 Bananas 30 $45 **
在上面的例子中,发生了两件重要的事情:
{ action ; }
组合, $3 <= 30{ printf "%s\t%s\n", $0,"**" ; }
打印出数量小于或等于的行 30
并添加一个 (**)
在每一行的末尾。数量的值是使用访问$3
变量。{ action ; }
组合, $3 > 30{ print $0 ;}
打印出未更改的行,因为它们的数量大于30
.再举一个例子:
> awk '$3 <= 20 { printf "%s\t%s\n", $0,"TRUE" ; } $3 > 20 { print $0 ;}' rumenz.txt
No Item_Name Quantity Price
1 Mangoes 45 $45
2 Apples 25 $45
3 Pineapples 5 $45 TRUE
4 Tomatoes 25 $45
5 Onions 15 $45 TRUE
6 Bananas 30 $45
在这个例子中,我们想要表示数量小于或等于
20
用这个词(TRUE)
在末尾。
相关文章