标签:har png 设置 inux graph 贪婪 文件 fat gre
基本语法
一个正则表达式通常被称为一个模式(pattern),为用来描述或者匹配一系列符合某个句法规则的字符串。
一、选择:|
二、数量限定:+ ? *
三、范围和优先级
()圆括号可以用来定义模式字符串的范围和优先级,这可以简单的理解为是否将括号内的模式串作为一个整体。例如,"gr(a|e)y"等价于"gray|grey",(这里体现了优先级,竖直分隔符用于选择a或者e而不是gra和ey),"(grand)?father"匹配father和grandfather(这里体验了范围,?将圆括号内容作为一个整体匹配)。
四、语法(部分)
正则表达式有多种不同的风格,下面列举一些常用的作为 PCRE 子集的适用于perl和python编程语言及grep或egrep的正则表达式匹配规则:(由于markdown表格解析的问题,下面的竖直分隔符用全角字符代替,实际使用时请换回半角字符)
PCRE(Perl Compatible Regular Expressions中文含义:perl语言兼容正则表达式)是一个用 C 语言编写的正则表达式函数库,由菲利普.海泽(Philip Hazel)编写。PCRE是一个轻量级的函数库,比Boost 之类的正则表达式库小得多。PCRE 十分易用,同时功能也很强大,性能超过了 POSIX 正则表达式库和一些经典的正则表达式库。
五、字符描述
六、优先级
优先级为从上到下从左到右,依次降低:
运算符 | 说明 |
\ | 转义符 |
(), (?:), (?=), [] | 括号和中括号 |
*、+、?、{n}、{n,}、{n,m} | 限定符 |
^、$、\任何元字符 | 定位点和序列 |
| | 选择 |
grep模式匹配命令
一、 基本操作
grep命令用于打印输出文本中匹配的模式串,它使用正则表达式作为模式匹配的条件。grep支持三种正则表达式引擎,分别用三个参数指定:
参数 说明
在通过grep命令使用正则表达式之前,先介绍一下它的常用参数:
参数 说明
使用正则表达式
使用基本正则表达式,BRE
位置
查找/etc/group文件中以"shiyanlou"为开头的行
$ grep ‘shiyanlou‘ /etc/group $ grep ‘^shiyanlou‘ /etc/group
数量
# 将匹配以‘z‘开头以‘o‘结尾的所有字符串 $ echo ‘zero\nzo\nzoo‘ | grep ‘z.*o‘ # 将匹配以‘z‘开头以‘o‘结尾,中间包含一个任意字符的字符串 $ echo ‘zero\nzo\nzoo‘ | grep ‘z.o‘ # 将匹配以‘z‘开头,以任意多个‘o‘结尾的字符串 $ echo ‘zero\nzo\nzoo‘ | grep ‘zo*‘ #注意:其中\n为换行符
选择
# grep默认是区分大小写的,这里将匹配所有的小写字母 $ echo ‘1234\nabcd‘ | grep ‘[a-z]‘ # 将匹配所有的数字 $ echo ‘1234\nabcd‘ | grep ‘[0-9]‘ # 将匹配所有的数字 $ echo ‘1234\nabcd‘ | grep ‘[[:digit:]]‘ # 将匹配所有的小写字母 $ echo ‘1234\nabcd‘ | grep ‘[[:lower:]]‘ # 将匹配所有的大写字母 $ echo ‘1234\nabcd‘ | grep ‘[[:upper:]]‘ # 将匹配所有的字母和数字,包括0-9,a-z,A-Z $ echo ‘1234\nabcd‘ | grep ‘[[:alnum:]]‘ # 将匹配所有的字母 $ echo ‘1234\nabcd‘ | grep ‘[[:alpha:]]‘
下面包含完整的特殊符号及说明:
特殊符号 说明
注意:之所以要使用特殊符号,是因为上面的[a-z]不是在所有情况下都管用,这还与主机当前的语系有关,即设置在LANG环境变量的值,zh_CN.UTF-8的话[a-z],即为所有小写字母,其它语系可能是大小写交替的如,"a A b B...z Z",[a-z]中就可能包含大写字母。所以在使用[a-z]时请确保当前语系的影响,使用[:lower:]则不会有这个问题。
# 排除字符
$ $ echo ‘geek\ngood‘ | grep ‘[^o]‘
注意:当^放到中括号内为排除字符,否则表示行首。
使用扩展正则表达式,ERE
要通过grep使用扩展正则表达式需要加上-E参数,或使用egrep。
数量
# 只匹配"zo" $ echo ‘zero\nzo\nzoo‘ | grep -E ‘zo{1}‘ # 匹配以"zo"开头的所有单词 $ echo ‘zero\nzo\nzoo‘ | grep -E ‘zo{1,}‘
注意:推荐掌握{n,m}即可,+,?,*,这几个不太直观,且容易弄混淆。
选择
# 匹配"www.shiyanlou.com"和"www.google.com" $ echo ‘www.shiyanlou.com\nwww.baidu.com\nwww.google.com‘ | grep -E ‘www\.(shiyanlou|google)\.com‘ # 或者匹配不包含"baidu"的内容 $ echo ‘www.shiyanlou.com\nwww.baidu.com\nwww.google.com‘ | grep -Ev ‘www\.baidu\.com‘
注意:因为.号有特殊含义,所以需要转义。
标签:har png 设置 inux graph 贪婪 文件 fat gre
原文地址:https://www.cnblogs.com/kumata/p/9014344.html