linux shell中Grep命令查找多个字符串(grep同时匹配多个关键字或任意关键字)

更新时间:2022-08-03 11:08:36

grep 命令支持三种正则表达式语法:Basic、Extended 和 Perl-compatible 。当没有指定正则表达式类型时,grep 命令将搜索模式默认为基本正则表达式。

fea1804ad3cf14160a326f207a3c16e9_1644898980-f89f523ceff0e7e.jpg

要搜索多个匹配模式,可以使用 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 在线帮助。

linuxshell