PHP中的另类奇葩 正则的讲解

作者: 君满楼001 | 来源:发表于2017-11-16 16:08 被阅读43次

    一,什么是正则:

    正则表达式是一种描述字符串结果的语法规则,是一个特定的格式化模式,可以匹配、替换、截取匹配的字符串。常用的语言基本上都有正则表达式,如JavaScript、java等。其实,只有了解一种语言的正则使用,其他语言的正则使用起来,就相对简单些。

    二,正则表达式的基本知识汇总:

    行定位符(^与$):

    行定位符是用来描述字符串的边界。

    “$”表示行结尾“^”表示行开始:

    如"^de",表示以de开头的字符串"de$",表示以de结尾的字符串。

    单词定界符(\b):

    我们在查找的一个单词的时候,如an是否在一个字符串”gril and body”中存在,很明显如果匹配的话,an肯定是可以匹配字符串“gril and body”匹配到,怎样才能让其匹配单词,而不是单词的一部分呢?这时候,我们可以是哟个单词定界符\b。

    \ban\b 去匹配”gril and body”的话,就会提示匹配不到。

    当然还有一个大写的\B,它的意思,和\b正好相反,它匹配的字符串不能使一个完整的单词,而是其他单词或字符串中的一部分。如\Ban\B。

    选择字符(|) ,表示或:

    选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”可以匹配任意长度的字符串。在使用”[]”的时候,往往配合连接字符”-“一起使用,如[a-d],代表a或b或c或d。

    排除字符,排除操作:

    正则表达式提供了”^”来表示排除不符合的字符,^一般放在[]中。如[^1-5],该字符不是1~5之间的数字。

    限定符(?*+{n,m})

    限定符主要是用来限定每个字符串出现的次数。

    限定字符含义

    ?    零次或一次{0,1}

    *    零次或多次{0,}

    +    一次或多次{1,}

    {n}n次

    {n,}至少n次

    {n,m}n到m次

    如(D+)表示一个或多个D

    点号操作符(.)

    匹配任意一个字符(不包含换行符)

    表达式中的反斜杠(\)

    表达式中的反斜杠有多重意义,如转义、指定预定义的字符集、定义断言、显示不打印的字符。

    转义字符

    转义字符主要是将一些特殊字符转为普通字符。而这些常用特殊字符有”.”,”?”、”\”等。

    指定预定义的字符集

    字符含义

    \d任意一个十进制数字[0-9]

    \D任意一个非十进制数字

    \s任意一个空白字符(空格、换行符、换页符、回车符、字表符)

    \S任意一个非空白字符

    \w任意一个单词字符

    \W任意个非单词字符

    ###显示不可打印的字符

    字符含义

    \a报警

    \b退格

    \f换页

    \n换行

    \r回车

    \t字表符

    括号字符()

    在正则表达式中小括号的作用主要有:

    改变限定符如(|、* 、^)的作用范围

    如(my|your)baby,如果没有”()”,|将匹配的是要么是my,要么是yourbaby,有了小括号,匹配的就是mybaby或yourbaby。

    进行分组,便于反向引用

    模式修饰符

    模式修饰符的作用是设定模式,也就是正则表达式如何解释。php中主要模式如下表:

    修饰符    说明         i   忽略大小写        m    多文本模式        s    单行文本模式        x    忽略空白字符

    使用正则进行匹配

    在php中,提供了preg_math()和preg_match_all函数进行正则匹配。关于这两个函数原型如下:

    int preg_match|preg_match_all (string$pattern ,string$subject [, array &$matches [,int$flags =0 [,int$offset =0 ]]] )

    搜索subject与pattern给定的正则表达式的一个匹配.

    pattern:要搜索的模式,字符串类型。

    subject :输入字符串。

    matches:如果提供了参数matches,它将被填充为搜索结果。matches[0]将包含完整模式匹配到的文本,matches[1]将包含第一个捕获子组匹配到的文本,以此类推。

    flags:flags可以被设置为以下标记值:PREG_OFFSET_CAPTURE 如果传递了这个标记,对于每一个出现的匹配返回时会附加字符串偏移量(相对于目标字符串的)。 注意:这会改变填充到matches参数的数组,使其每个元素成为一个由 第0个元素是匹配到的字符串,第1个元素是该匹配字符串 在目标字符串subject中的偏移量。

    offset:通常,搜索从目标字符串的开始位置开始。可选参数 offset 用于 指定从目标字符串的某个未知开始搜索(单位是字节)。

    返回值:preg_match()返回 pattern 的匹配次数。 它的值将是0次(不匹配)或1次,因为 preg_match()在第一次匹配后 将会停止搜索。 preg_match_all()不同于此,它会一直搜索subject直到到达结尾。 如果发生错误 preg_match()返回 FALSE。

    php中贪婪匹配与惰性匹配

    贪婪匹配:就是匹配尽可能多的字符。

    比如,正则表达式中m.*n,它将匹配最长以m开始,n结尾的字符串。如果用它来搜索manmpndegenc的话,它将匹配到的字符串是manmpndegen而非man。可以这样想,当匹配到m的时候,它将从后面往前匹配字符n。

    懒惰匹配:就是匹配尽可能少的字符。

    有的时候,我们需要并不是去贪婪匹配,而是尽可能少的去匹配。这时候,就需要将其转为惰性匹配。怎样将一个贪婪匹配转为惰性匹配呢?只需要在其后面添加一个”?”即可。如m.*?n将匹配manmpndegenc,匹配到的字符串是man。

    函数符描述

    *?零次或多次,但尽可能少的匹配

    +?一次或多次,但尽可能少的匹配

    ??0次或1次,但尽可能少的匹配

    {n,}?至少n次,但尽可能少的匹配

    {n,m}?n到m次 ,但尽可能少的匹配

    相关文章

      网友评论

        本文标题:PHP中的另类奇葩 正则的讲解

        本文链接:https://www.haomeiwen.com/subject/mvwlvxtx.html