如何递归地grep所有目录和子目录?

find . | xargs grep "texthere" *

当前回答

在IBM AIX Server(操作系统版本:AIX 5.2)中,使用:

find ./ -type f -print -exec grep -n -i "stringYouWannaFind" {} \; 

这将打印出文件中的路径/文件名和相对行号,如:

./inc/xxxx_x.h

2865:/**描述:stringYouWanna查找*/

无论如何,这对我来说很有用:)

其他回答

另一种语法递归地grep Linux系统上所有文件中的字符串

grep-irn“字符串”

-r表示递归搜索,在给定目录和子目录中搜索指定字符串,在文件、程序等中查找指定字符串

-不区分大小写可用于添加大小写颠倒的字符串

-n打印指定字符串的行号

注意:这会将大量结果打印到控制台,所以您可能需要通过管道过滤输出,并删除不太有趣的信息,它还会搜索二进制程序,因此您可能需要过滤一些结果

球状物**

使用grep-r是可行的,但可能会过度使用,尤其是在大型文件夹中。

对于更实际的用法,以下是使用globbing语法(**)的语法:

grep "texthere" **/*.txt

它只greps具有模式选择模式的特定文件。它适用于受支持的shell,如Bash+4或zsh。

要激活此功能,请运行:shopt-s globstar。

另请参阅:如何在Linux上查找包含特定文本的所有文件?

数字grep

对于Git版本控制下的项目,请使用:

git grep "pattern"

这要快得多。

里普雷普

对于较大的项目,最快的grepping工具是ripgrep,默认情况下递归地对文件进行grep:

rg "pattern" .

它建立在Rust的正则表达式引擎之上,该引擎使用有限自动机、SIMD和激进的文字优化,使搜索速度非常快。查看此处的详细分析。

只是为了好玩,如果@christangrant的答案太多而无法输入,可以快速搜索*.txt文件:-)

grep-r文本此处|grep.txt文件

我想这就是你想写的

grep myText $(find .)

如果你想找到grep命中的文件,这可能是其他有用的东西

grep myText $(find .) | cut -d : -f 1 | sort | uniq

有关可用标志的列表:

grep --help 

返回当前目录中此处的regexp文本的所有匹配项,以及相应的行号:

grep -rn "texthere" .

返回文本的所有匹配项,从根目录开始,具有相应的行号,忽略大小写:

grep -rni "texthere" /

此处使用的标志:

-r递归-n带输出的打印行号-我不理这个案子