我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。

grep 'string1\|string2' filename

那么我如何匹配与grep只包含两个字符串的行?


当前回答

如果git被初始化并添加到分支,那么最好使用git grep,因为它非常快,它会在整个目录内搜索。

git grep 'string1.*string2.*string3'

其他回答

假设我们需要在文件testfile中找到多个单词的计数。 有两种方法

1)使用grep命令与regex匹配模式

grep -c '\<\(DOG\|CAT\)\>' testfile

2)使用egrep命令

egrep -c 'DOG|CAT' testfile 

使用egrep,您无需担心表达式,只需通过管道分离器分离单词。

如果您有一个grep,其中有一个-P选项用于有限的perl regex,您可以使用

grep -P '(?=.*string1)(?=.*string2)'

它的优点是处理重叠的字符串。使用perl作为grep更直接,因为你可以更直接地指定and逻辑:

perl -ne 'print if /string1/ && /string2/'

搜索两个String,只突出显示string1和string2

grep -E 'string1.*string2|string2.*string1' filename | grep -E 'string1|string2'

or

grep 'string1.*string2\|string2.*string1' filename | grep -E 'string1\|string2'
grep -i -w 'string1\|string2' filename

这适用于精确的单词匹配和匹配不区分大小写的单词,为此使用-i

对于多行匹配:

echo -e "test1\ntest2\ntest3" |tr -d '\n' |grep "test1.*test3"

or

echo -e "test1\ntest5\ntest3" >tst.txt
cat tst.txt |tr -d '\n' |grep "test1.*test3\|test3.*test1"

我们只需要删除换行符,它就工作了!