时间:2021-05-02
语法:grep 选项 ‘word' filename
-c:打印符合要求的行数
-i:不区分大小写
-n:在输出符合要求的行的同时显示行号
-v:打印不符合要求的行
-A:后跟一个数字n,表示打印符合要求的行以及下面n行
-B:后跟一个数字n,表示打印符合要求的行以及上面n行
-C:后跟一个数字n,表示打印符合要求的行以及上下各n行
-r:会把目录下所有的文件全部遍历
--color:把匹配到的关键词用红色标示
例子:
过滤出带有某个关键词的行并输出行号
grep -n ‘root' 1.txt
过滤出不带有某个关键词的行并输出行号
grep -nv ‘root' 1.txt
过滤出所有包含数字的行
grep ‘[0-9]‘ 1.txt
过滤出所有不包含数字的行
grep -v ‘[0-9]‘ 1.txt
去除所有以#开头的行
grep -v ‘^#‘ 1.txt
去除所有空行和以#开头的行
grep -v ‘^$‘ 1.txt|grep -v ‘^#‘
过滤出以英文字母开头的行
grep ‘^[a-zA-Z]‘ 1.txt
过滤出以非数字开头的行
grep -v ‘^[0-9]‘ 1.txt或者grep ‘^[^0-9]‘ 1.txt
过滤任意一个或多个字符
grep ‘r.o‘ 1.txt;grep ‘rt‘ 1.txt ;grep ‘r.t‘ 1.txt
过滤出包含root的行以及下面一行
grep -A1 ‘root‘ 1.txt
过滤出包含root的行以及上面一行
grep -B1 ‘root‘ 1.txt
指定过滤字符次数
grep ‘o{2}‘ 1.txt
把一个目录下,过滤所有.php文档中含有eval的行
grep -r --include=".php" ‘eval‘ /data/
过滤两个或多个关键词
grep -E ‘123|abc‘ filename #找出文件中包含123或者abc的行
或者egrep ‘123|abc‘ filename
或者awk ‘/123|abc/‘ filename
egrep=grep -E
匹配1个或者1个以上+前面的字符
egrep ‘o+‘ 1.txt
匹配0个或者1个?前面的字符
egrep ‘o?‘ 1.txt
匹配roo或者匹配body
egrep ‘roo|body‘ 1.txt
用括号表示一个整体,下面例子会匹配roo或者ato
egrep ‘r(oo)|(at)o‘ 1.txt
匹配1个或者多个oo
egrep ‘(oo)+‘ 1.txt
.:表示任意一个字符
:表示0个或多个前面的字符
+:表示1个或多个+前面的字符
?:表示0个或1个?前面的字符
.*:表示任意个任意字符(包含空行)
注意:+和?grep不支持,egrep才支持。
总结
以上所述是小编给大家介绍的正则表达式grep用法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.mamicode.com/info-detail-2359759.html
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
3.1查找文本grep:使用POSIX定义的基本正则表达式(BRE)。egrep:使用扩展正则表达式(ERE)。fgrep:快速grep。使用优化的算法,匹配固
正则表达式是一种符号表示法,用于识别文本模式。Linux处理正则表达式的主要程序是grep。grep搜索与正则表达式匹配的行,并将结果输送至标准输出。1.gre
下面会举几个在grep命令中使用正则表达式从一个文件中匹配到特定的IP地址。下面的正则表达式将会匹配IPV4的地址。正则表达式匹配IP地址:使用下面的正则表达式
来学习下搜索文件中内容的基本操作,然后下载我们的备忘录作为grep和正则表达式的快速参考指南。grep(全局正则表达式打印GlobalRegularExpres
一正则表达式与通配符1正则表达式是用在文件中匹配符合条件的字符串,正则是包含匹配,grep,awk,sed等命令可以支持正则表达式2通配符是用来匹配符合条件的文