如何在 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()" *
上面的命令将尝试main()在特定目录和子目录中的所有文件中查找字符串“func ”。
输出结果
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() {}
以上是 如何在 Linux 上抑制 grep 中的二进制文件匹配结果? 的全部内容, 来源链接: utcz.com/z/338819.html