如何使用awk按模式筛选文本或字符串

介绍

这篇文章主要介绍如何使用awk按模式筛选文本或字符串,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

<强>在筛选文本时,有时你可能想根据某个给定的条件或使用一个可被匹配的特定模式,去标记某个文件或数行字符串中的某几行。使用awk来完成这个任务是非常容易的,这也正是awk中可能对你有所帮助的几个功能之一。

如何使用awk按模式筛选文本或字符串

让我们看一看下面这个例子,比方说你有一个写有你想要购买的食物的购物清单,其名称为food_prices。列表,它所含有的食物名称及相应的价格如下所示:

猫food_prices美元。列表没有Item_Name数量价格2.45美元1芒果10 2苹果20 1.50美元3香蕉5 0.90 4菠萝10 3.46美元5橙子10 0.78 6番茄5 0.55美元7 alt="如何使用awk按模式筛选文本或字符串">

打印出单价大于2美元的项目

从上面的输出你可以看到在含有芒果和菠萝的那行末尾都已经有了一个(*)标记。假如你检查它们的单价,你可以看到它们的单价的确超过了2美元。

在这个例子中,我们已经使用了两个模式:

第一个模式:/*/(2 - 9)/美元。[0 - 9][0 - 9]*/将会得到那些含有食物单价大于2美元的行。

第二个模式:/*/(0 - 1)/美元。[0 - 9][0 - 9]*/将查找那些食物单价小于2美元的那些行。

上面的命令具体做了什么呢?这个文件有四个字段,当模式一匹配到含有食物单价大于2美元的行时,它便会输出所有的四个字段并在该行末尾加上一个符(*)号来作为标记。

第二个模式只是简单地输出其他含有食物单价小于2美元的行,按照它们出现在输入文件food_prices。列表中的样子。

这样你就可以使用模式来筛选出那些价格超过2美元的食物项目,尽管上面的输出还有些问题,带有符(*)号的那些行并没有像其他行那样被格式化输出,这使得输出显得不够清晰。

我们在awk系列的第二部分中也看到了同样的问题,但我们可以使用下面的两种方式来解决:

1,可以像下面这样使用printf命令,但这样使用又长又无聊:

awk & # 39;美元/*/(2 - 9)/美元。[0 - 9][0 - 9]*/{printf“-10年代-10年代-10年代% % % %/n" -10年代,$ 1,$ 2,3美元,4美元“*”;;}/*/(0 - 1)/美元。[0 - 9][0 - 9]*/{printf“-10年代-10年代-10年代% % % %/n" -10年代,$ 1,$ 2,3美元,4美元;}& # 39;food_prices。列表

如何使用awk按模式筛选文本或字符串

2,使用$ 0字段.Awk使用变量,<强> 0 ,来存储整个输入行。对于上面的问题,这种方式非常方便,并且它还简单,快速:

awk & # 39;美元/*/(2 - 9)/美元。[0 - 9][0 - 9]*/{print $ 0“*”;;}/*/(0 - 1)/美元。[0 - 9][0 - 9]*/{打印;}& # 39;food_prices。列表

如何使用awk按模式筛选文本或字符串

以上是“如何使用awk按模式筛选文本或字符串”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

如何使用awk按模式筛选文本或字符串