如何查找包含less数特定string但不一定在同一行中的所有文件?

在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