我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
当前回答
如果git被初始化并添加到分支,那么最好使用git grep,因为它非常快,它会在整个目录内搜索。
git grep 'string1.*string2.*string3'
其他回答
grep '(string1.*string2 | string2.*string1)' filename
将得到line与string1和string2在任何顺序
将您想要grep的字符串放入文件中
echo who > find.txt
echo Roger >> find.txt
echo [44][0-9]{9,} >> find.txt
然后使用-f进行搜索
grep -f find.txt BIG_FILE_TO_SEARCH.txt
你可以使用
grep 'string1' filename | grep 'string2'
Or
grep 'string1.*string2\|string2.*string1' filename
对于多行匹配:
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"
我们只需要删除换行符,它就工作了!
假设我们需要在文件testfile中找到多个单词的计数。 有两种方法
1)使用grep命令与regex匹配模式
grep -c '\<\(DOG\|CAT\)\>' testfile
2)使用egrep命令
egrep -c 'DOG|CAT' testfile
使用egrep,您无需担心表达式,只需通过管道分离器分离单词。