Linux grep多个关键字“与”和“或”使用详解

Linux grep命令用于查找文件里符合条件的字符串。
grep指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为"-",则grep指令会从标准输入设备读取数据。

一、或(or)操作
1、使用 \|
grep 'a1\|a2' filename     //找出文件(filename)中包含a1或者包含a2的行

2、使用选项 -E
grep -E 'a1|a2'filename    // 找出文件(filename)中包含a1或者包含a2的行

3、使用egrep
egrep 'a1|a2' filename     // 用egrep同样可以实现

4、使用选项 -e
使用grep -e 选项,只能传递一个参数。在单条命令中使用多个 -e 选项
grep -e a1 -e a2 filename  //使用-e选项实现

5、使用awk
awk '/a1|a2/' filename     // awk 的实现方式

备注:推荐使用方法3


二、与(and)操作
1、使用 -E 'par1.*par2'
grep命令本身不提供AND功能。但是,使用 -E 选项可以实现AND操作。
例1(其中两个pattern的顺序是指定的):

grep -E 'a1.*a2' filename
例2(两个pattern的顺序不是固定的,可以是乱序的):
grep -E 'a1.*a2|a2.*a1' filename

2、使用多个grep命令
grep "a1" filename | grep "a2"  //找出既匹配 a1 又匹配 a2 的行
三、非(not)操作
1、使用选项 grep -v
使用 grep -v 可以实现 NOT 操作。-v 选项用来实现反选匹配的( invert match)。如,可匹配得到除下指定pattern外的所有lines。

grep -v 'par1' filename

2、将NOT操作与其他操作联合起来,以此实现更强大的功能组合
示例(将得到:'a1或者a2,但是不是a3'的结果):
egrep 'a1|a2' filename | grep -v a3
四、其他操作
grep -i pattern files  //不区分大小写地搜索,默认情况区分大小写;
grep -l pattern files  //只列出匹配的文件名;
grep -L pattern files  //列出不匹配的文件名;
grep -w pattern files  //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不‘magical’);
grep -C number pattern files //匹配的上下文分别显示[number]行。

五、应用示例
1、列出同时包含这两个关键词(a1和a2)的文件及包含的次数
grep -l "a1" |xargs grep -c "a2"

六、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:在线帮助。



本文参考资料:http://www.runoob.com/linux/linux-comm-grep.html
http://www.tuicool.com/articles/6VJzI3v
https://www.jianshu.com/p/4ec50fdaf388
  • 17
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值