首页 > 语言 > PHP > 正文

php正则修正符用法实例介绍

2024-09-04 11:47:38
字体:
来源:转载
供稿:网友

本文实例讲述了php正则修正符用法,分享给大家供大家参考,具体如下:

  1. <?php 
  2.     //标记在整个模式之外; 
  3.    // 例://$mode="//bis/b/U",其中U在外面; 
  4.    //修正符:i 不区分大小写的匹配; 
  5.       //如:"/abc/i"可以与abc或aBC或ABc等匹配; 
  6.    //修正符:m 将字符串视为多行,不管是那行都能匹配; 
  7.    //  例://模式为:$mode="/abc/m"; 
  8.       //要匹配的字符串为:$str="bcefg5e/nabcdfe" 
  9.       //注意其中/n,换行了;abc换到了下一行; 
  10.       //$str和$mode仍可以匹配,修正符m使得多行也可匹配; 
  11.    //修正符:s 将字符串视为单行,换行符作为普通字符; 
  12.     // 例://模式为:$mode="/pr.y/"; 
  13.        //要匹配字符串为:$str="pr/ny"; 
  14.        //两者不可匹配; . 是除了换行以外的字符可匹配; 
  15.        //修改下模式为:$mode="/pr.y/s"; 
  16.          //其中修正符s将/n视为普通字符,即不是换行; 
  17.        //最后两者可以匹配; 
  18.    //修正符:x 将模式中的空白忽略; 
  19.    //修正符:A 强制从目标字符串开头匹配; 
  20.     // 例://$mode="/abc/A"; 
  21.        //可以与$str="abcsdfi"匹配, 
  22.        //不可以与$str2="sdsdabc"匹配; 
  23.        //因为$str2不是以abc开头; 
  24.    //修正符:D 如果使用$限制结尾字符,则不允许结尾有换行; 
  25.    //  例://模式为:$mode="/abc$/"; 
  26.        //可以与最后有换行的$str="adshabc/n"匹配; 
  27.        //元子符$会忽略最后的换行/n; 
  28.        //如果模式为:$mode="/abc/D", 
  29.        //则不能与$str="adshabc/n"匹配, 
  30.        //修正符D限制其不可有换行;必需以abc结尾; 
  31.    //修正符:U 只匹配最近的一个字符串;不重复匹配; 
  32.    //  例: 
  33.    //   如模式为: 
  34.        $mode="/a.*c/"
  35.        $str="abcabbbcabbbbbc"
  36.        preg_match($mode,$str,$content); 
  37.        echo$content[0];//输出:abcabbbcabbbbbc; 
  38.        //如果$mode="/a.*c/";变成$mode="/a.*c/U"; 
  39.        // 则只匹配最近一个字符串,输出:abc; 
  40.  //修正符:e 配合函数preg_replace()使用, 
  41.  //      可以把匹配来的字符串当作正则表达式执行; 
  42.  ?> 

修正符:

POSIX兼容正则没有修正符。

PERL兼容正则中可能使用的修正符(修正符中的空格和换行被忽略,其它字符会导致错误):

i(PCRE_CASELESS):

匹配时忽略大小写。

m(PCRE_MULTILINE):

当 设定了此修正符,行起始(^)和行结束($)除了匹配整个字符串开头和结束外,还分别匹配其中的换行符(/n)的之后和之前。

s(PCRE_DOTALL):

如 果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。

x(PCRE_EXTENDED):

如 果设定了此修正符,模式中的空白字符除了被转义的或在字符类中的以外完全被忽略。

e:

如果设 定了此修正符,preg_replace() 在替换字符串中对逆向引用作正常的替换,将其作为 PHP 代码求值,并用其结果来替换所搜索的字符串。 只有 preg_replace() 使用此修正符,其它 PCRE 函数将忽略之。

A(PCRE_ANCHORED):

如果设定了此修正符,模式被强制为“anchored”,即强制仅从目标字符串的开头开始匹配。

D(PCRE_DOLLAR_ENDONLY):

如 果设定了此修正符,模式中的行结束($)仅匹配目标字符串的结尾。没有此选项时,如果最后一个字符是换行符的话,也会被匹配在里面。如果设定了 m 修正符则忽略此选项。

S:

当一个模式将被使用若干次时,为加速匹配起见值得先对其进行分析。 如果设定了此修正符则会进行额外的分析。目前,分析一个模式仅对没有单一固定起始字符的 non-anchored 模式有用。

U(PCRE_UNGREEDY):

使 “?”的默认匹配成为贪婪状态的。

X(PCRE_EXTRA):

模式中的任何反斜线后面跟上 一个没有特殊意义的字母导致一个错误,从而保留此组合以备将来扩充。默认情况下,一个反斜线后面跟一个没有特殊意义的字母被当成该字母本身。

u(PCRE_UTF8):

模 式字符串被当成UTF-8。

注意:

模式修正符(Pattern Modifiers)

i     -可同时匹配大小写字母

M     -将字符串视为多行

S     -将字符串视为单行,换行符做普通字符看待,使“.”匹配任何字符

X     -模式中的空白忽略不计

U     -匹配到最近的字符串

e     -将替换的字符串作为表达使用

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表