如何在Linux上找到包含特定文本的所有文件?

我正在尝试找到一种方法来扫描整个Linux系统,查找包含特定文本字符串的所有文件.只是为了澄清,我在文件中寻找文本,而不是文件名.

当我查找如何做到这一点时,我遇到了两次这个解决方案:

find / -type f -exec grep -H 'text-to-find-here' {} ;
find / -type f -exec grep -H 'text-to-find-here' {} ;

但是,它不起作用.它似乎显示系统中的每个文件.

这是否接近正确的方法呢?如果没有,我该怎么办?这种在文件中查找文本字符串的能力对于我正在做的一些编程项目非常有用.

回答

请执行下列操作:

grep -rnw '/path/to/somewhere/' -e 'pattern'
  • -r或者-R是递归的,
  • -n 是行号,和
  • -w 代表整个单词的匹配.
  • -l (小写L)可以添加到只给出匹配文件的文件名.

除了这些,--exclude,--include,--exclude-dir标志可用于高效搜索:

  • grep --include=*.{c,h} -rnw '/path/to/somewhere/' -e "pattern"
    
  • grep --exclude=*.o -rnw '/path/to/somewhere/' -e "pattern"
    
  • grep --exclude-dir={dir1,dir2,*.dst} -rnw '/path/to/somewhere/' -e "pattern"
    

这对我来说非常有效,可以达到和你一样的目的.

有关更多选项检查man grep.

  • 值得注意的是:似乎`r`选项是懒惰的(遍历深度优先,而不是在第一个目录之后停止),而`R`是贪婪的(将正确遍历整个树).
  • 使用--exclude.比如"grep -rnw --exclude =*.o'目录'-e"模式"
  • @Eliran Malka`R`en`r`将正确遍历目录,但`R`将遵循符号链接.
  • 注意(特别是对于新手):上述命令中的引号很重要.
  • *grep -rnw"我正在寻找的字符串"*完成了我需要的工作.谢谢!
  • 您还可以添加 --colour/--color 以突出显示您的搜索词。例如`grep -rnw --colour 。-e“终端”`
  • -e 代表什么?
  • 我该怎么做才能忽略二进制文件呢?
  • 不要忘记通过在命令末尾添加“2> /dev/null”来告诉 Linux 不要向您显示您不需要的东西。这是唯一不会收到大量 Permission Denied 警告的方法,这些警告只会混淆您正在寻找的结果。
  • 它是否在目录中的隐藏文件/目录中搜索?
  • 谁能解释为什么包含参数--include = \ *。{c,h}中包含?谢谢
  • 我发现`-i`选项对于"忽略大小写"也非常有用.也许把它放在你的选项列表中.
  • 这是一个可靠的答案,但问题是它只能匹配整个单词,因为它使用了 `-w` 参数。我发现它不会匹配任意文本。

你可以使用grep -ilR:

grep -Ril "text-to-find-here" /
  • i 代表忽略大小写(在您的情况下是可选的).
  • R 代表递归.
  • l 代表"显示文件名,而不是结果本身".
  • / 代表从机器的根开始.
  • 根据我的经验,`-i`使它减慢很多,所以如果没有必要,不要使用它.在某个目录中测试然后进行推广.它应该在几分钟内完成.我认为正则表达式会让它变慢.但我的评论是基于假设,我建议你用前面的'time`来测试它.
  • 您可以将目录`grep -Ril"替换为/ text-to-find-here"〜/ sites /`或使用.当前目录`grep -Ril"text-to-find-here".`
  • 如果您不使用正则表达式进行搜索,则可以在大多数系统上使用fgrep代替grep.
  • 是的@ markle976,实际上来自man grep:`fgrep与grep -F相同 - >解释PATTERN作为固定字符串列表`.
  • 是的,`/*`代表那个.无论如何,我只是测试它,并注意到只有`/`工作.
  • @Nathan 在所有这些时间之后(并且超过一百万次观看!)我注意到您可以添加参数`-I`(大写 i)来排除二进制文件。我认为这是这里的关键点,而不是 `exclude` 或 `include`。迟到总比不到好:D
  • @Cleb 见 [grep,但只有某些文件扩展名](/sf/ask/876185621/)

你可以使用ack.它就像grep的源代码.您可以使用它扫描整个文件系统.

做就是了:

ack 'text-to-find-here'

在根目录中.

您还可以使用正则表达式,指定文件类型等.


UPDATE

我刚刚发现了The Silver Searcher,它类似于ack但比它快3-5倍,甚至忽略了.gitignore文件中的模式.

  • 非常有用,简单而快速.警告:"在Debian派生的发行版上,ack打包为"ack-grep",因为"ack"已经存在"(来自http://beyondgrep.com/install/).您最终可能会在这些Linux上运行一个汉字代码转换器......
  • ack或ack-grep有很好的亮点,但是当正确使用时性能要好得多,找到+ grep
  • 请注意,[ripgrep](https://github.com/BurntSushi/ripgrep)比这里提到的任何其他内容都要快,包括The Silver Searcher和简单的'ol grep.有关证据,请参阅[此博客文章](http://blog.burntsushi.net/ripgrep/).

您可以使用:

grep -r "string to be searched"  /path/to/dir

r代表递归等都将在路径搜索指定的也是它的子目录.这将告诉您文件名以及打印出字符串出现的文件中的行.

或者类似于您正在尝试的命令(例如:)用于搜索所有javascript文件(*.js):

find . -name '*.js' -exec grep -i 'string to search for' {} ; -print

这将打印出现文本的文件中的行,但不会打印文件名.

除了这个命令,我们也可以写这个:
grep -rn"要搜索的字符串"/ path /到/ directory /或/ file
-r:递归搜索
n:将显示匹配的行号

  • 谢谢你的'发现'版本!能够按'*.js'或'*.txt'等过滤是非常重要的.没有人愿意花几个小时等待grep完成搜索上一次家庭度假的所有多GB视频,即使命令更容易输入.

你可以用这个:

grep -inr "Text" folder/to/be/searched/
  • 最简单,详细,递归和不区分大小写.竖起大拇指.

包含给定文本的文件名列表

首先,我相信你用的是-H代替-l.您也可以尝试在引号后面添加文本{} .

find / -type f -exec grep -l "text-to-find-here" {} ;

假设您正在搜索目录中包含特定文本"Apache License"的文件.它将显示与下面类似的结果(输出将根据您的目录内容而有所不同).

bash-4.1$ find . -type f -exec grep -l "Apache License" {} ;
./net/java/jvnet-parent/5/jvnet-parent-5.pom
./commons-cli/commons-cli/1.3.1/commons-cli-1.3.1.pom
./io/swagger/swagger-project/1.5.10/swagger-project-1.5.10.pom
./io/netty/netty-transport/4.1.7.Final/netty-transport-4.1.7.Final.pom
./commons-codec/commons-codec/1.9/commons-codec-1.9.pom
./commons-io/commons-io/2.4/commons-io-2.4.pom
bash-4.1$

区分大小写敏感度

即使您不使用"text"与"TEXT"之类的情况,也可以使用-i开关忽略大小写.你可以阅读更多细节在这里.

希望这对你有所帮助.

  • 这个命令的作用是什么:`find`将它找到的所有路径传递给命令`grep -l"text-to-find-here"<file found>"`.你可以对文件名添加限制,例如`find/-iname"*.txt"`只搜索名称以`.txt`结尾的文件
  • @Mene这是一个真正令人悲伤的状态,Auxiliary的评论比你的评论更多......即使他们的评论来自2014年,而你的评论是2017年,他们的评论是6,当它应该正好为0而你的只有一个(现在是两个)isn我想要相信的东西.

grep(GNU或BSD)

您可以使用grep工具递归搜索当前文件夹,例如:

grep -r "class foo" .

注意:-r- 递归搜索子目录.

您还可以使用通配语法在特定文件中进行搜索,例如:

grep "class foo" **/*.c

注意:通过使用globbing选项(**),它以递归方式扫描具有特定扩展名或模式的所有文件.要启用此语法,请运行:shopt -s globstar.您还可以使用**/*.*所有文件(隐藏和不扩展)或任何其他模式.

如果您的错误是您的参数太长,请考虑缩小搜索范围,或使用find语法,例如:

find . -name "*.php" -execdir grep -nH --color=auto foo {} ';'

或者使用ripgrep.

ripgrep

如果你正在处理更大的项目或大文件,你应该使用ripgrep,比如:

rg "class foo" .

查看GitHub项目页面上的文档,安装步骤或源代码.

它比其他工具一样快多了GNU/BSD grep,ucg,ag,sift,ack,pt或类似的,因为它是建立在之上锈病的正则表达式引擎,它使用有限自动机,SIMD和积极文字的优化,使搜索速度非常快.

它支持忽略.gitignore文件中指定的模式,因此可以同时针对多个glob模式匹配单个文件路径.


您可以使用常用参数,例如:

  • -i - 不敏感的搜索.
  • -I - 忽略二进制文件.
  • -w - 搜索整个单词(与部分单词匹配相反).
  • -n - 显示你的比赛线.
  • -C/ --context(例如-C5) - 增加上下文,以便查看周围的代码.
  • --color=auto - 标记匹配的文本.
  • -H - 显示找到文本的文件名.
  • -c - 显示匹配行的计数.可以结合使用-H.
  • 对于吸入整个文件系统, rg 将远比几乎任何其他工具都少痛苦。
  • 我还发现扩展的通配符很有用。但请记住,如果文件数量真的很大,您可能会收到“参数列表太长”错误。(简单的 globbing 也容易出现这种错误)。

如果您grep不支持递归搜索,则可以结合find使用xargs:

find / -type f | xargs grep 'text-to-find-here'

我发现这比格式更容易记住find -exec.

这将输出文件名和匹配行的内容,例如

/home/rob/file:text-to-find-here

您可能要添加的可选标志grep:

  • -i - 不区分大小写的搜索
  • -l - 仅输出找到匹配项的文件名
  • -h - 只输出匹配的行(不是文件名)
  • 如果`find`找不到任何东西,这相当于没有文件名的'grep'text-to-find-here'.这将挂起并等待用户输入!添加`--no-run-if-empty`作为`xargs`的选项.
  • 如果文件或目录名称包含空格(xargs解释为分隔符的字符),则find和xargs的组合不会按预期工作.使用`find ... -exec grep ... +`.如果你坚持将find与xargs一起使用,请使用`-print0`和`-0`.

grep -insr "pattern" *
  • i:忽略PATTERN和输入文件中的大小写区别.
  • n:在输入文件中使用基于1的行号为每行输出添加前缀.
  • s:禁止有关不存在或不可读文件的错误消息.
  • r:递归地读取每个目录下的所有文件.
  • @ AmosM.Carpenter我喜欢这个答案的一件事是指出抑制论证,它可以帮助滤除与获得我们实际想要的结果无关的噪音.Grep在某些"文件"上打印诸如"功能未实现","无效参数","资源不可用"等错误.
  • 你能解释一下你的答案如何改进其他答案,或者它们与它们有多大不同?

我两次遇到这个解决方案:

find / -type f -exec grep -H 'text-to-find-here' {} ;


如果在您的示例中使用find,则更好地添加-s(--no-messages)grep以及2>/dev/null在命令的末尾,以避免由和发出的大量Permission denied消息:grepfind

find / -type f -exec grep -sH 'text-to-find-here' {} ; 2>/dev/null

find是在类Unix平台上搜索文件的标准工具 - 在查找特定文本时与grep结合使用.在查找命令经常联合 xargs的,顺便说一句.

为同一目的存在更快更容易的工具 - 见下文.如果它们在您的平台上可用,请更好地尝试它们,当然:

更快更容易的替代品

RipGrep - 最快的搜索工具:

rg 'text-to-find-here' / -l

银色搜索者:

ag 'text-to-find-here' / -l

确认:

ack 'text-to-find-here' / -l

注意:您也可以添加2>/dev/null这些命令,以隐藏许多错误消息.


警告:除非你真的无法避免它,否则不要在'/'(根目录)中搜索以避免长时间和低效的搜索!因此,在上面的示例中,您最好用子目录名替换' / ',例如"/ home"取决于您实际想要搜索的位置...


有一个名为The Silversearcher的新工具

sudo apt install silversearcher-ag

它与Git和其他VCS密切合作.所以你不会在.git或其他目录中获得任何东西.

你可以简单地使用

ag "Search query"

它会为你完成任务!


尝试:

find . -name "*.txt" | xargs grep -i "text_pattern"
  • 这实际上是一个很好的例子,当不使用像这样的`xargs`时......考虑一下.```echo"文件bar.txt有条"> bar.txt; echo"file foo bar.txt has foo bar">"foo bar.txt"; 回声"你永远不应该看到这个foo"> foo; 找 .-name"*.txt"| xargs grep -i foo#./ foo:你永远不应该看到这个foo```.这里的`xargs`与WRONG文件匹配,与预期的文件不匹配.要么使用`find .. -print0 | xargs -0 ...`但这是一个无用的管道或更好的`find ... -exec grep ... {} +`

用于pwd从您所在的任何目录中搜索,向下递归

grep -rnw `pwd` -e "pattern"

更新
根据您使用的grep版本,您可以省略pwd..如果没有给出目录,那么在较新版本上似乎是grep的默认情况:

grep -rnw -e "pattern"

要么

grep -rnw "pattern"

会做同上面的事情!

  • 使用`pwd`根本不需要,因为它是默认值.`grep -rnw"pattern"`就够了.

grep 即使我们不寻找字符串也可以使用.

只需跑步,

grep -RIl "" .

将打印出所有文本文件的路径,即仅包含可打印字符的文件.

  • 我没有看到这比使用单纯的`ls`或`find`更好(对于递归)

以下是可用于搜索文件的几个命令列表.

grep "text string to search” directory-path
grep [option] "text string to search” directory-path
grep -r "text string to search” directory-path
grep -r -H "text string to search” directory-path
egrep -R "word-1|word-2” directory-path
egrep -w -R "word-1|word-2” directory-path
  • 这增加了现有的答案是什么?

Silver Searcher是一个了不起的工具,但ripgrep可能会更好.

它可以在Linux,Mac和Windows上运行,并且在几个月前写在Hacker News上(这有一个链接到Andrew Gallant的Blog,它有一个GitHub链接):

Ripgrep - 一种新的命令行搜索工具


find /path -type f -exec grep -l "string" {} ;

评论解释

find是一个命令,可以让您在给定路径的子目录中查找文件和其他对象,如目录和链接.如果未指定文件名应满足的掩码,则枚举所有目录对象.

-type f specifies that it should proceed only files, not directories etc.
-exec grep specifies that for every found file, it should run grep command, passing its filename as an argument to it, by replacing {} with the filename

希望这有助于......

扩展grep一点以在输出中提供更多信息,例如,获取文本所在文件中的行号可以按如下方式完成:

find . -type f -name "*.*" -print0 | xargs --null grep --with-filename --line-number --no-messages --color --ignore-case "searthtext"

如果你知道文件类型是什么,你可以通过指定要搜索的文件类型扩展来缩小搜索范围,在这种情况下是.pasOR .dfm文件:

find . -type f ( -name "*.pas" -o -name "*.dfm" ) -print0 | xargs --null grep --with-filename --line-number --no-messages --color --ignore-case "searchtext"

选项的简短说明:

  1. .find当前目录的指定中.
  2. -name" *.*":对于所有文件(-name" *.pas" - o -name" *.dfm"):仅指定*.pasOR *.dfm文件或OR-o
  3. -type f 指定您正在查找文件
  4. -print0并且--null|(管道)的另一端是关键的,将文件名从嵌入传递findgrep嵌入式xargs,允许在文件名中传递带有空格的文件名,允许grep将路径和文件名视为一个字符串,而不是在每个空间分手.

尝试:

这将搜索所有文件系统,因为/是根文件夹.

对于主文件夹使用:

find ~/ -type f -exec grep -H 'text-to-find-here' {} ;

对于当前文件夹使用:

find ./ -type f -exec grep -H 'text-to-find-here' {} ;

一个简单的find工作方便.在您的~/.bashrc文件中将其别名:

alias ffind find / -type f | xargs grep

启动新终端并发出:

ffind 'text-to-find-here'

我写了一个Python脚本,它做了类似的事情.这就是人们应该如何使用这个脚本.

./sniff.py path pattern_to_search [file_pattern]

第一个参数path是我们将递归搜索的目录.第二个参数pattern_to_search是我们想要在文件中搜索的正则表达式.我们使用Python re库中定义的正则表达式格式.在此脚本中,.还匹配换行符.

第三个参数file_pattern是可选的.这是另一个适用于文件名的正则表达式.仅考虑与此正则表达式匹配的那些文件.

例如,如果我想搜索py包含Pool(后跟单词的扩展名的Python文件Adaptor,我会执行以下操作,

./sniff.py . "Pool(.*?Adaptor"  .*py
./Demos/snippets/cubeMeshSigNeur.py:146
./Demos/snippets/testSigNeur.py:259
./python/moose/multiscale/core/mumbl.py:206
./Demos/snippets/multiComptSigNeur.py:268

瞧,它会生成匹配文件的路径和找到匹配项的行号.如果找到多个匹配项,则每个行号将附加到文件名.


使用:

grep -c Your_Pattern *

这将报告当前目录中每个文件中有多少个模式副本.


grep是你实现这一目标的好朋友.

grep -r <text_fo_find> <directory>

如果你不关心文本的情况下找到然后使用

grep -ir <text_to_find> <directory>

要搜索字符串并使用搜索字符串输出该行:

for i in $(find /path/of/target/directory -type f); do grep -i "the string to look for" "$i"; done

例如:

for i in $(find /usr/share/applications -type f); 
do grep -i "web browser" "$i"; done

要显示包含搜索字符串的文件名:

for i in $(find /path/of/target/directory -type f); do if grep -i "the string to look for" "$i" > /dev/null; then echo "$i"; fi; done;

例如:

for i in $(find /usr/share/applications -type f); 
do if grep -i "web browser" "$i" > /dev/null; then echo "$i"; 
fi; done;

有一种ack工具可以完全满足您的需求.

http://linux.die.net/man/1/ack

ack -i search_string folder_path/*

您可以忽略-i区分大小写的搜索

  • 这增加了现有的答案是什么?三年多前就提出过这个建议.

所有以前的答案都建议grep并找到.但还有另一种方法:使用午夜指挥官

它是一个免费的实用程序(30岁,经过时间证明),它是视觉上没有GUI.有大量功能,查找文件只是其中之一.


我很着迷于grep用'rl'做出的简单方法

grep -rl 'pattern_to_find' /path/where/to/find
-r to find recursively file / directory inside directories..
-l to list files matching the 'pattern'
grep -r 'pattern_to_find' /path/where/to/find

工作得很完美..

希望能帮助到你!


如果您严格要使用find那么:

find + grep

find /path/to/somewhere/ -type f -exec grep -nw 'textPattern' {} ;

1. find使用搜索文件,然后执行grep所有文件.

可以在一个命令中组合如下:

find

  • find /path/to/somewhere/ -type f -name *.cpp -exec grep -nw 'textPattern' {} ;

这可以让您find找到文件的强大功能.您可以使用它并使用不同的选项find来改进或缩小文件搜索范围.


试试这个:

find . | xargs grep 'word' -sl
  • 这比grep解决方案要慢得多

您可以使用以下命令,因为您不想要文件名但想要从所有文件中搜索.这是我正在捕获"TEXT"表单所有日志文件,确保不打印文件名

grep -e TEXT *.log | cut -d' ' --complement -s -f1

与其他选项相比,使用-e选项的grep非常快,因为它适用于PATTERN匹配


以下命令适用于此方法:

find ./ -name "file_pattern_name"  -exec grep -r "pattern" {} ;
  • 使用`find`然后`grep -r`是什么意思?它们也是相同的,所以这是多余的.
  • 不过,这没有任何意义,你可以用`find`过滤.

避免麻烦并安装ack-grep.它消除了许多许可和报价问题.

apt-get install ack-grep

然后转到要搜索的目录并运行以下命令

cd /
ack-grep "find my keyword"

grep -Erni + "text you wanna search"

该命令将在当前目录的所有文件和目录中以递归方式搜索并打印结果.

注意:如果你的grep输出没有着色,你可以在shell src文件中使用grep ='grep --color = always'别名来更改它


如果您有一组始终要检查的文件,则可以为其路径添加别名,例如:

alias fd='find . -type f -regex ".*.(inc|info|module|php|test|install|uninstall)"'

然后你可以像这样过滤列表:

grep -U -l $'15' $(fd)

其中将列表fd筛选出包含CR模式的文件.

我发现别名我感兴趣的文件可以帮助我创建更简单的脚本,然后总是试图记住如何获取所有这些文件.递归的东西也可以工作,但迟早你将不得不面对清除特定的文件类型.这就是为什么我只是找到我感兴趣的所有文件类型的原因.


试试这个:

find / -type f -name "*" -exec grep -il "String_to_search" {} ;

要么

for i in /*;do grep -Ril "String_to_search" $i;done 2> /dev/null

您可以使用以下命令从文件中查找特定文本:

cat file | grep 'abc' | cut -d':' -f2

正如彼得在上一篇回答中提到的那样,之前的所有答案都表明了grep并找到

但是有更复杂的方式使用Gnome Commander具有完美的GUI和自2001年以来的大量选项,找到文件只是其中之一.它是一种免费的实用工具,经过时间证明.


findxarg■当存在很多潜在的去筛选匹配是优选的.它的运行速度比其他选项慢,但它始终有效.正如一些人所发现的xargs那样,默认情况下不处理带有嵌入空格的文件.您可以通过指定-d选项来克服此问题.

这是@ RobEarl的答案,增强了所以它处理带空格的文件:

find / -type f | xargs -d 'n' grep 'text-to-find-here'

这是@ venkat的答案,同样增强了:

find . -name "*.txt" | xargs -d 'n' grep -i "text_pattern"

这是@Gert van Biljon的答案,同样增强了:

find . -type f -name "*.*" -print0 | xargs -d 'n' --null grep --with-filename --line-number --no-messages --color --ignore-case "searthtext"

这是@ LetalProgrammer的答案,同样增强了:

alias ffind find / -type f | xargs -d 'n' grep

这是@Tayab Hussain的答案,同样增强了:

find . | xargs -d 'n' grep 'word' -sl

试试这个

find . -type f -name some_file_name.xml -exec grep -H PUT_YOUR_STRING_HERE {} ;
  • @SergeyDenisov是什么给出的?这绝对是一个答案.(它是否有效是另一回事.)
  • @jpaugh我确定一行命令/代码不足以完整答案.您可以撰写评论,提供建议的行动方案,但答案应包括解释.这就是为什么这个答案被标记为"低质量帖子"(不是我).

虽然您永远不应该用不同的程序替换(或别名)系统命令,但由于脚本或其他实用程序的神秘损坏风险,如果您手动或从您自己的脚本或程序运行文本搜索,您应该考虑最快的合适的程序在多次搜索大量文件时使用。在对您描述的用例进行几次使用后,可以恢复花费十分钟到半小时的时间来安装和熟悉更好的实用程序。

提供“ ack、ag、git-grep、GNU grep 和 ripgrep 的功能比较”的网页可以帮助您确定哪个程序提供了您需要的功能。

  • 以下命令搜索所有文件,包括隐藏文件和可执行文件:

    $ rg -uuu foobar

对于速度和强大的索引查询语言(例如ElasticSearch或Solr)的组合,可以是一项有回报的长期投资,但如果您想要快速简单地替代 grep,则不是。OTOH 都有一个可以从您编写的任何程序中调用的 API,为您的程序添加强大的搜索功能。

虽然可以生成外部程序、执行搜索、拦截其输出并对其进行处理,但调用 API 是提高功率和性能的方法。

虽然一些答案提出了完成搜索的替代方法,但除了“免费”、“更快”、“更复杂”、“大量功能”等之外,它们并没有解释为什么。不要试图出售它,只需告诉我们“为什么你的答案是正确的”。我试图教如何选择最适合用户的东西,以及为什么. 这就是为什么我提供另一个答案的原因,因为已经有这么多答案了。否则我会同意已经有很多答案了;我希望我带来了很多新东西。


grep "text-to-find-here" file_name

或者

grep "text-to-find-here" directory_path/*

如果要搜索当前目录:

grep "text-to-find-here" *

GUI搜索备选方案-桌面使用:

-由于问题并非精确地要求命令

Searchmonkey:高级文件搜索工具,而无需使用正则表达式对系统进行索引。图形等效于find / grep。适用于Linux(Gnome / KDE / Java)和Windows(Java)-开源GPL v3

特征:

  • 高级正则表达式
  • 结果显示在上下文中
  • 搜索包含文字
  • 面板显示包含文本的行
  • 2018年新更新
  • 等等

下载-链接:

  • 主页:http://searchmonkey.embeddediq.com/
  • 下载:http : //searchmonkey.embeddediq.com/index.php/download-latest
  • 回购:https : //sourceforge.net/projects/searchmonkey/files/

屏幕截图:


另请参阅Platinium Searcher,它类似于The Silver Searcher,它是用Go编写的.

例:

pt -e 'text to search'

您可以使用ripgrep它将默认尊重项目的.gitignore文件

抑制Permission denied错误

rg -i rustacean 2> /dev/null

这会将stderr(标准错误输出)重定向到/dev/null


以上是如何在Linux上找到包含特定文本的所有文件?的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>