日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

linux?shell中Grep命令查找多個字符串(grep同時匹配多個關鍵字或任意關鍵字)_linux shell

作者:慕城南風 ? 更新時間: 2022-09-27 編程語言

前言

grep 命令支持三種正則表達式語法:Basic、Extended 和 Perl-compatible 。當沒有指定正則表達式類型時,grep 命令將搜索模式默認為基本正則表達式。

要搜索多個匹配模式,可以使用 OR ( alternation ) 運算符。我們可以用 OR 運算符 |( pipe )指定不同的匹配項,這些匹配項可以是文本字符串,也可以是表達式集。值得注意的是,在所有正則表達式運算符中,這個運算符的優先級是最低的。

使用 grep 命令基本正則表達式搜索多個匹配模式的語法如下:

$ grep 'pattern1\|pattern2' filename 

這里需要注意的是,始終要用單引號將正則表達式括起來,因為單引號內的內容原樣輸出,被單引號括起的內容不管是常量還是變量不會發生替換。

使用基本正則表達式時,元字符被解釋為字面字符。要保留元字符的特殊含義,必須用反斜杠( \ )對它們進行轉義。這就是為什么我們要轉義 OR 運算符(|)。

要將模式解釋為擴展正則表達式,請調用 grep -E(或 --extended-regexp )選項。使用擴展正則表達式時,不需要對 OR 運算符 (|) 進行轉義:

$ grep -E 'pattern1|pattern2' file 

1.Grep命令搜索多個字符串

通常我們認為,文字字符串是最基本的模式。

接下來我們將示例,搜索某用戶日志錯誤文件中出現的所有 fatal、error 和 critical 字符串。語法如下:

$ grep 'fatal\|error\|critical' /var/log/nginx/error.log 

還需要注意的是,如果要搜索的字符串包含空格,需要用雙引號將其括起來。

下面是使用擴展正則表達式的同一個示例,它不需要轉義字符:

$ grep -E 'fatal|error|critical' /var/log/nginx/error.log 

默認情況下,grep 命令是區分大小寫的。要在搜索時忽略大小寫,請調用 grep 加 -i (或 --ignore-case )選項,示例如下:

$ grep -i 'fatal|error|critical' /var/log/nginx/error.log 

當你只想搜索某個單詞時,比如你想搜索的是單詞 error ,grep 命令會輸出所有包含 error 字符串的行,即它除了會輸出包含 error 單詞的行,還會輸出包含 errorless 或 antiterrorists 等非 error 單詞的行,這樣是極不方便的。

因此要僅返回指定字符串是整詞的行,或者是由非單詞字符括起來的行,可以使用 grep 加 -w (或 --word-regexp )選項:

$ grep -w 'fatal|error|critical' /var/log/nginx/error.log 

值得注意的是,單詞字符包括有字母、數字字符(比如 a-z、a-Z 和 0-9 )以及下劃線( _ ),所有其他字符都被視為非單詞字符。

2.grep同時匹配多個關鍵字或任意關鍵字

2.1與操作

grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。

grep word1 file.txt | grep word2 |grep word3

必須同時滿足三個條件(word1、word2和word3)才匹配。

2.2 或操作

grep匹配任意關鍵字

grep -E 'str1|str2|str3' filename //找出文件(filename)中包含str1或者包含str2或者包含str3的行

egrep實現

egrep 'str1|str2|str3' filename //用egrep同樣可以實現

awk實現

awk '/str1|str2/str3/' filename  //awk 的實現方式

2.3其他操作

grep -i pattern filename #不區分大小寫地搜索。默認情況區分大小寫。
grep -l pattern filename #只列出匹配的文件名。
grep -L pattern filename #列出不匹配的文件名。
grep -w pattern filename #只匹配整個單詞,而不是字符串的一部分(如匹配‘magic',而不是‘magical')。

附:grep參數說明

  • -a或--text 不要忽略二進制的數據。
  • -A<顯示列數>或--after-context=<顯示列數> 除了顯示符合范本樣式的那一列之外,并顯示該列之后的內容。
  • -b或--byte-offset 在顯示符合范本樣式的那一列之前,標示出該列第一個字符的位編號。
  • -B<顯示列數>或--before-context=<顯示列數> 除了顯示符合范本樣式的那一列之外,并顯示該列之前的內容。
  • -c或--count 計算符合范本樣式的列數。
  • -C<顯示列數>或--context=<顯示列數>或-<顯示列數> 除了顯示符合范本樣式的那一列之外,并顯示該列之前后的內容。
  • -d<進行動作>或--directories=<進行動作> 當指定要查找的是目錄而非文件時,必須使用這項參數,否則grep指令將回報信息并停止動作。
  • -e<范本樣式>或--regexp=<范本樣式> 指定字符串做為查找文件內容的范本樣式。
  • -E或--extended-regexp 將范本樣式為延伸的普通表示法來使用。
  • -f<范本文件>或--file=<范本文件> 指定范本文件,其內容含有一個或多個范本樣式,讓grep查找符合范本條件的文件內容,格式為每列一個范本樣式。
  • -F或--fixed-regexp 將范本樣式視為固定字符串的列表。
  • -G或--basic-regexp 將范本樣式視為普通的表示法來使用。
  • -h或--no-filename 在顯示符合范本樣式的那一列之前,不標示該列所屬的文件名稱。
  • -H或--with-filename 在顯示符合范本樣式的那一列之前,表示該列所屬的文件名稱。
  • -i或--ignore-case 忽略字符大小寫的差別。
  • -l或--file-with-matches 列出文件內容符合指定的范本樣式的文件名稱。
  • -L或--files-without-match 列出文件內容不符合指定的范本樣式的文件名稱。
  • -n或--line-number 在顯示符合范本樣式的那一列之前,標示出該列的列數編號。
  • -q或--quiet或--silent 不顯示任何信息。
  • -r或--recursive 此參數的效果和指定"-d recurse"參數相同。
  • -s或--no-messages 不顯示錯誤信息。
  • -v或--revert-match 反轉查找。
  • -V或--version 顯示版本信息。
  • -w或--word-regexp 只顯示全字符合的列。
  • -x或--line-regexp 只顯示全列符合的列。
  • -y 此參數的效果和指定"-i"參數相同。
  • --help 在線幫助。

參考文章:

1.grep同時匹配多個關鍵字或任意關鍵字

2.grep多個關鍵字“與”和“或”

3.grep 滿足 或 排除多個關鍵字

4.如何使用Grep命令查找多個字符串

總結

原文鏈接:https://blog.csdn.net/lovedingd/article/details/116532053

欄目分類
最近更新