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

前端之家收集整理的这篇文章主要介绍了在Ubuntu的grep中,如何只显示与正则表达式匹配的字符串?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我基本上是用正则表达式来表达.在输出中,我只想看到与我的reg exp匹配的字符串.

在一堆XML文件(主要是它们是一行中有大量数据的单行文件)中,我想得到所有以MAIL_开头的单词.

此外,我希望shell上的grep命令只给出匹配的单词,而不是整行(在这种情况下是整个文件).

我该怎么做?

我努力了

grep -Gril MAIL_* .
grep -Grio MAIL_* .
grep -Gro MAIL_* .
首先,使用与Ubuntu一起安装的GNU grep,-G标志(使用基本的regexp)是默认的,所以你可以省略它,但是更好的是使用扩展的regexp与-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相关文章