Linux grep多个关键字“与”和“或”使用详解
grep指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。-f或–file=: 指定范本文件,其内容含有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每列一个范本样式。-C或–context=或-: 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。-e或–regexp=: 指定字符串做为
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:在线帮助。
————————————————
版权声明:本文为CSDN博主「CannerG」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/volcano2339/article/details/115947208
更多推荐
所有评论(0)