如何在 Linux 上抑制 grep 中匹配二进制文件的搜索结果?


Linux 中的 grep 命令用于在文件中过滤搜索特定字符模式。它是 Linux 中最常用的实用程序命令之一,用于显示包含我们试图搜索的模式的行。

通常,我们在文件中尝试搜索的模式被称为正则表达式。

语法

grep [options] pattern [files]

虽然我们有很多不同的选项可用,但其中一些最常用的选项是 -

-c : It lists only a count of the lines that match a pattern
-h : displays the matched lines only.
-i : Ignores, case for matching
-l : prints filenames only
-n : Display the matched lines and their line numbers.
-v : It prints out all the lines that do not match the pattern

现在,让我们考虑一个我们想要在特定目录(例如 dir1)中的所有文件中查找特定模式的情况。

语法

grep -rni "word" *

在上面的命令中,用以下内容替换“word”占位符

为此,我们使用以下所示的命令 -

grep -rni "func main()" *

上述命令将尝试在特定目录中的所有文件中以及子目录中查找字符串“func main()”。

输出

main.go:120:func main() {}

如果我们只想在单个目录中查找特定模式,而不是在子目录中查找,则需要使用以下所示的命令 -

grep -s "func main()" *

在上面的命令中,我们使用了**-s**标志,这将帮助我们避免在运行命令的目录中存在的每个子目录中收到警告。

输出

main.go:120:func main() {}

现在我们知道了 grep 命令在 Linux 中是如何工作的。如果我们想要忽略所有来自二进制文件的匹配项,那么我们可以使用以下所示的标志以及 grep 命令

标志

-I -- process a binary file as if it did not contain matching data;
-n -- prefix each line of output with the 1-based line number within its input file
-H -- print the file name for each match

命令

grep -I -n -H “func main()” *

输出

main.go:120:func main() {}

更新于: 2021年7月31日

693 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告