在linux中, grep -r <string> <path>
是find<path>
下所有文件实例的常用方法,它基本上给你<path>
下包含<string>
所有文件。 但是如果我想查找所有包含less量string的文件呢? 从grep -r <string1> <path> | grep <string2>
grep -r <string1> <path> | grep <string2>
我可以将包含<string1>
和<string2>
所有文件都包含在同一行中,但是如何才能将包含<string1>
和<string2>
的文件分隔开来?
你可以试试
grep -rl searchstring1 . | xargs grep -l searchstring2
获取目录中的文件名列表.
包含两个搜索searchstring
(不一定在同一行)。 你可以级联,以防你想要更多的搜索字符串:
grep -rl searchstring1 . \ | xargs grep -l searchstring2 \ | xargs grep -l searchstring3
这是非常棘手的情况下,如果你在文件名中有空格和其他讨厌的字符,那么xargs
会被愚弄。 在这种特殊情况下(或者只是为了避免这个问题),你可以使用0字节的结束字符串:
grep -rlZ searchstring1 . \ | xargs -0 grep -lZ searchstring2 \ | xargs -0 grep -l searchstring3
并检查输出,你可以使用像:
grep -rlZ searchstring1 . \ | xargs -0 grep -lZ searchstring2 \ | xargs -0 grep -lZ searchstring3 \ | xargs -0 egrep 'searchstring2|searchstring2|searchstring3' /dev/null \ | less
一个完全不同的方法是直接使用find
(但是会启动大量的grep
进程,因此可能效率较低):
find . -type f \( \ -exec grep -q searchstring1 {} \; -a \ -exec grep -q searchstring2 {} \; -a \ -exec grep -q searchstring2 {} \; \) -print