如何在 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 次瀏覽

開啟你的 職業生涯

透過完成課程獲得認證

開始學習
廣告

© . All rights reserved.