如何在 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
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP