如何在 Linux 中使用 grep 匹配一行中存在的兩個字串?


為了能夠在 Linux 命令列中使用 **grep** 查詢同一行上存在的兩個字串,我們首先必須瞭解 **grep** 命令是什麼以及如何在 Linux 上使用它。

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() {}

現在,假設我有一個 **.txt** 檔案,檔案內容如下所示。

immukul@192 d2 % cat 2.txt
orange apple is great together

apple not great

is apple good

orange good apple not

現在,我想對包含兩個單詞 “apple” 和 “orange” 的所有行使用 **grep** 命令。

命令

grep 'orange' 2.txt | grep 'apple'

輸出

immukul@192 d2 % grep 'orange' 2.txt | grep 'apple'

orange apple is great together
orange good apple not

更新於:2021年7月30日

980 次瀏覽

啟動你的職業生涯

透過完成課程獲得認證

開始學習
廣告
© . All rights reserved.