PHP正则表达式 /i, /s, /x,/u, /U, /A, /D, /S等模式修饰符

转载来自:http://liheanyway007.blog.163.com/blog/static/181773148201262952341896/



i (PCRE_CASELESS)

如果设置了这个修饰符模式中的字母会进行大小写不敏感匹配.

m (PCRE_MULTILINE)

默认情况下, PCRE认为目标字符串是由单行字符组成的(然而实际上它可能会包含多行), "行首"元字符(^)仅匹配字符串的开始位置"行末"元字符($)仅匹配字符串末尾或者最后的换行符(除非设置了D修饰符). 这个行为和perl相同当这个修饰符设置之后, "行首""行末"就会匹配目标字符串中任意换行符之前或之后另外还分别匹配目标字符串的最开始和最末尾位置这等同于perl/m修饰符如果目标字符串 中没有"\n"字符或者模式中没有出现^$, 设置这个修饰符不产生任何影响.

s (PCRE_DOTALL)

如果设置了这个修饰符模式中的点号元字符匹配所有字符包含换行符如果没有这个 修饰符点号不匹配换行符这个修饰符等同于perl中的/s修饰符.一个取反字符类比如 [^a]总是匹配换行符而不依赖于这个修饰符的设置.

x (PCRE_EXTENDED)

如果设置了这个修饰符模式中的没有经过转义的或不在字符类中的空白数据字符总会被忽略并且位于一个未转义的字符类外部的#字符和下一个换行符之间的字符也被忽略这个修饰符 等同于perl中的/x修饰符使被编译模式中可以包含注释注意这仅用于数据字符空白字符 还是不能在模式的特殊字符序列中出现比如序列(?(引入了一个条件子组(译注这种语法定义的 特殊字符序列中如果出现空白字符会导致编译错误比如( ?(就会导致错误.).

(PREG_REPLACE_EVAL)

如果这个修饰符设置了preg_replace()在进行了对替换字符串的 后向引用替换之后将替换后的字符串作为php代码评估执行(eval函数方式), 并使用执行结果 作为实际参与替换的字符串单引号双引号反斜线(\)NULL字符在后向引用替换时会被用反斜线转义.

Tip

请确保replacement参数由合法php代码字符串组成否则php将会 preg_replace()调用的行上 产生一个解释错误.

Note preg_replace()使用此修饰符其他PCRE函数忽略此修饰符.

A (PCRE_ANCHORED)

如果设置了这个修饰符模式被强制为"锚定"模式也就是说约束匹配使其仅从 目标字符串的开始位置搜索这个效果同样可以使用适当的模式构造出来,并且 这也是perl种实现这种模式的唯一途径.

D (PCRE_DOLLAR_ENDONLY)

如果这个修饰符被设置模式中的元字符美元符号仅仅匹配目标字符串的末尾如果这个修饰符 没有设置当字符串以一个换行符结尾时美元符号还会匹配该换行符(但不会匹配之前的任何换行符). 如果设置了修饰符m这个修饰符被忽略perl中没有与此修饰符等同的修饰符.

S

当一个模式需要多次使用的时候为了得到匹配速度的提升值得花费一些时间 对其进行一些额外的分析如果设置了这个修饰符这个额外的分析就会执行当前这种对一个模式的分析仅仅适用于非锚定模式的匹配(即没有单独的固定开始字符).

U (PCRE_UNGREEDY)

这个修饰符逆转了量词的"贪婪"模式使量词默认为非贪婪的通过量词后紧跟?的方式可以使其成为贪婪的这和perl是不兼容的它同样可以使用 模式内修饰符设置(?U)进行设置或者在量词后以问号标记其非贪婪(比如.*?).

Note:

在非贪婪模式通常不能匹配超过 pcre.backtrack_limit的字符.

X (PCRE_EXTRA)

这个修饰符打开了PCREperl不兼容的附件功能模式中的任意反斜线后就ingen一个 没有特殊含义的字符都会导致一个错误以此保留这些字符以保证向后兼容性默认 情况下perl反斜线紧跟一个没有特殊含义的字符被认为是该字符的原文当前没有其他特性由这个修饰符控制.

(PCRE_INFO_JCHANGED)

内部选项设置(?J)修改本地的PCRE_DUPNAMES选项允许子组重名. (译注:只能通过内部选项设置外部的/J设置会产生错误.)

(PCRE8)

此修正符打开一个与perl不兼容的附加功能模式字符串被认为是utf-8这个修饰符 unixphp 4.1.0或更高, win32php 4.2.3开始可用. php 4.3.5开始检查模式的utf-8合法性. This modifier turns on additional functionality of PCRE that is incompatible with Perl. Pattern strings are treated as UTF-8. This modifier is available from PHP 4.1.0 or greater on Unix and from PHP 4.2.3 on win32. UTF-8 validity of the pattern is checked since PHP 4.3.5.


posted @ 2014-11-02 22:02  梦回丶故里  阅读(141)  评论(0编辑  收藏  举报