我基本上是用正则表达式来表达.在输出中,我只想看到与我的reg exp匹配的字符串.
在一堆XML文件(主要是它们是一行中有大量数据的单行文件)中,我想得到所有以MAIL_开头的单词.
此外,我希望shell上的grep命令只给出匹配的单词,而不是整行(在这种情况下是整个文件).
我该怎么做?
我努力了
grep -Gril MAIL_* . grep -Grio MAIL_* . grep -Gro MAIL_* .
首先,使用与Ubuntu一起安装的GNU grep,-G标志(使用基本的regexp)是默认的,所以你可以省略它,但是更好的是使用扩展的regexp与-E.
而且,您使用-o标志来打印匹配的行的一部分是正确的.另外,要省略文件名,你需要一个-h标志.
你唯一的错误是正则表达式本身.你错过了*之前的字符规范.你的命令应该是这样的:
grep -Ehro 'MAIL_[^[:space:]]*' .
示例输出(不递归):
$echo "Some garbage MAIL_OPTION comes MAIL_VALUE here" | grep -Eho 'MAIL_[^[:space:]]*' MAIL_OPTION MAIL_VALUE