我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
当前回答
你的方法几乎很好,只是少了一个-w
grep -w 'string1\|string2' filename
其他回答
在任意位置搜索包含所有单词的任意顺序的文件:
grep -ril \'action\' | xargs grep -il \'model\' | xargs grep -il \'view_type\'
第一个grep启动递归搜索(r),忽略大小写(i)并列出(打印出)文件中任何地方出现的与(l)匹配的一个项(带有单引号的'action')的文件名。
后续的grep搜索其他术语,保留大小写不敏感并列出匹配文件。
您将获得的最终文件列表将是包含这些术语的文件,在文件的任何位置以任意顺序排列。
grep -i -w 'string1\|string2' filename
这适用于精确的单词匹配和匹配不区分大小写的单词,为此使用-i
正则表达式中的|操作符表示或。也就是说,string1或string2将匹配。你可以这样做:
grep 'string1' filename | grep 'string2'
它将把第一个命令的结果输送到第二个grep中。这应该只会给出两者都匹配的行。
如果git被初始化并添加到分支,那么最好使用git grep,因为它非常快,它会在整个目录内搜索。
git grep 'string1.*string2.*string3'
ripgrep
下面是使用rg的例子:
rg -N '(?P<p1>.*string1.*)(?P<p2>.*string2.*)' file.txt
它是最快的抓取工具之一,因为它建立在Rust的正则引擎之上,该引擎使用有限自动机、SIMD和积极的文字优化来使搜索非常快。
使用它,特别是在处理大量数据时。
参见GH-875中的相关功能请求。