我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
当前回答
grep -i -w 'string1\|string2' filename
这适用于精确的单词匹配和匹配不区分大小写的单词,为此使用-i
其他回答
在任意位置搜索包含所有单词的任意顺序的文件:
grep -ril \'action\' | xargs grep -il \'model\' | xargs grep -il \'view_type\'
第一个grep启动递归搜索(r),忽略大小写(i)并列出(打印出)文件中任何地方出现的与(l)匹配的一个项(带有单引号的'action')的文件名。
后续的grep搜索其他术语,保留大小写不敏感并列出匹配文件。
您将获得的最终文件列表将是包含这些术语的文件,在文件的任何位置以任意顺序排列。
搜索两个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的字符串放入文件中
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 -i -w 'string1\|string2' filename
这适用于精确的单词匹配和匹配不区分大小写的单词,为此使用-i
发现仅以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