如何解决如何在 Linux 上查找包含特定文本的所有文件?
您可以使用grep -ilR
:
grep -Ril "text-to-find-here" /
-
i
代表忽略大小写(在您的情况下可选)。 -
R
代表递归。 -
l
代表“显示文件名,而不是结果本身”。 -
/
代表从机器的根开始。
请执行下列操作:
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/somewhere/' -e "pattern"
这对我来说非常有效,可以实现与您几乎相同的目的。
有关更多选项,请检查man grep
。
解决方法
我试图找到一种方法来扫描我整个 Linux 系统中包含特定文本字符串的所有文件。澄清一下,我正在文件中查找文本,而不是文件名中的文本。
当我在寻找如何做到这一点时,我两次遇到了这个解决方案:
find / -type f -exec grep -H 'text-to-find-here' {} \;
但是,它不起作用。它似乎显示了系统中的每个文件。
这接近正确的方法吗?如果没有,我该怎么办?这种在文件中查找文本字符串的能力对于我正在做的一些编程项目非常有用。