如何在 Linux 上查找包含特定文本(字符串)的所有文件?

新手上路,请多包涵

如何在文件内容中找到包含特定文本字符串的所有文件?

以下不起作用。它似乎显示了系统中的每个文件。

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

原文由 Nathan 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 606
2 个回答

请执行下列操作:

 grep -rnw '/path/to/somewhere/' -e 'pattern'

  • -r-R 是递归的,
  • -n 是行号,并且
  • -w 表示匹配整个单词。
  • -l (小写L)可以添加以仅给出匹配文件的文件名。
  • -e 是搜索过程中使用的模式

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

  • 这只会搜索具有 .c 或 .h 扩展名的文件:
   grep --include=\*.{c,h} -rnw '/path/to/somewhere/' -e "pattern"

  • 这将排除搜索所有以 .o 扩展名结尾的文件:
   grep --exclude=\*.o -rnw '/path/to/somewhere/' -e "pattern"

  • 对于目录,可以使用 --exclude-dir 参数排除一个或多个目录。例如,这将排除目录 dir1/dir2/ 以及所有匹配 *.dst/ 的目录:
   grep --exclude-dir={dir1,dir2,*.dst} -rnw '/path/to/search/' -e "pattern"

这对我来说非常有效,可以实现与您几乎相同的目的。

有关更多选项,请参阅 man grep

原文由 rakib_ 发布,翻译遵循 CC BY-SA 4.0 许可协议

使用 grep -ilR

 grep -Ril "text-to-find-here" /

  • i 代表忽略大小写(在您的情况下是可选的)。
  • R 代表递归。
  • l 代表“显示文件名,而不是结果本身”。
  • / 代表从你机器的根目录开始。

原文由 fedorqui 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题