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

grep 'string1\|string2' filename

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


当前回答

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

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

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

2)使用egrep命令

egrep -c 'DOG|CAT' testfile 

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

其他回答

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

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

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

2)使用egrep命令

egrep -c 'DOG|CAT' testfile 

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

grep '(string1.*string2 | string2.*string1)' filename

将得到line与string1和string2在任何顺序

发现仅以6个空格开始并以以下内容结束的行:

 cat my_file.txt | grep
 -e '^      .*(\.c$|\.cpp$|\.h$|\.log$|\.out$)' # .c or .cpp or .h or .log or .out
 -e '^      .*[0-9]\{5,9\}$' # numers between 5 and 9 digist
 > nolog.txt

正如人们建议的perl和python,以及复杂的shell脚本,这里有一个简单的awk方法:

awk '/string1/ && /string2/' filename

看了评论,得到了公认的答案:不,这没有多行;但这也不是问题作者想要的。

正则表达式中的|操作符表示或。也就是说,string1或string2将匹配。你可以这样做:

grep 'string1' filename | grep 'string2'

它将把第一个命令的结果输送到第二个grep中。这应该只会给出两者都匹配的行。