我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
我试图使用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,您无需担心表达式,只需通过管道分离器分离单词。
其他回答
你应该有这样的grep:
$ grep 'string1' file | grep 'string2'
如果您有一个grep,其中有一个-P选项用于有限的perl regex,您可以使用
grep -P '(?=.*string1)(?=.*string2)'
它的优点是处理重叠的字符串。使用perl作为grep更直接,因为你可以更直接地指定and逻辑:
perl -ne 'print if /string1/ && /string2/'
在任意位置搜索包含所有单词的任意顺序的文件:
grep -ril \'action\' | xargs grep -il \'model\' | xargs grep -il \'view_type\'
第一个grep启动递归搜索(r),忽略大小写(i)并列出(打印出)文件中任何地方出现的与(l)匹配的一个项(带有单引号的'action')的文件名。
后续的grep搜索其他术语,保留大小写不敏感并列出匹配文件。
您将获得的最终文件列表将是包含这些术语的文件,在文件的任何位置以任意顺序排列。
grep '(string1.*string2 | string2.*string1)' filename
将得到line与string1和string2在任何顺序
对于多行匹配:
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"
我们只需要删除换行符,它就工作了!