gpt4 book ai didi

ubuntu - 在 Ubuntu 上的 grep 中,如何只显示与正则表达式匹配的字符串?

转载 作者:太空宇宙 更新时间:2023-11-03 16:43:01 24 4
gpt4 key购买 nike

我基本上是在使用正则表达式进行 grepping。在输出中,我只想看到与我的 reg exp 匹配的字符串。

在一堆XML文件中(大多是单行文件,一行有大量数据),我想获取所有以MAIL_开头的单词。

另外,我希望 shell 上的 grep 命令只给出匹配的单词而不是整行(在本例中是整个文件)。

我该怎么做?

我试过了

grep -Gril MAIL_* .
grep -Grio MAIL_* .
grep -Gro MAIL_* .

最佳答案

首先,对于与 Ubuntu 一起安装的 GNU grep,-G 标志(使用基本正则表达式)是默认设置,因此您可以省略它,但更好的是,使用带有 -E 的扩展正则表达式。

-r 标志表示在目录的文件内进行递归搜索,这就是您所需要的。

并且,您使用 -o 标志来打印一行的匹配部分是正确的。此外,要省略文件名,您将需要一个 -h 标志。

您犯的唯一错误是正则表达式本身。您在 * 之前错过了字符规范。您的命令应如下所示:

grep -Ehro 'MAIL_[^[:space:]]*' .

示例输出(非递归):

$ echo "Some garbage MAIL_OPTION comes MAIL_VALUE here" | grep -Eho 'MAIL_[^[:space:]]*'
MAIL_OPTION
MAIL_VALUE

关于ubuntu - 在 Ubuntu 上的 grep 中,如何只显示与正则表达式匹配的字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3423728/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com