了解正向预查&反向预查前,我们先要知道正则的2个函数:preg_match_all 、 preg_replace
正向或反向预查都是非获取匹配,不进行存储供以后使用。
(?:pattern) 匹配结果
(?=pattern) 正向匹配
(?!pattern) 正向不匹配
(?<=pattern) 反向匹配。
(?<!pattern) 反向不匹配。
什么叫非获取匹配(非捕获匹配),请看例子
$str = 'xxxxjava6java7xxxx';$perg = "/java(6|7)/"; //匹配java6 获取 javapreg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '$str = 'xxxxjava6java7xxxx';$perg = "/java(6|7)/"; //匹配java6 获取 javapreg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '\0', $str); //"xxxxjava6java7xxxx"$str2 = preg_replace($perg, '\1', $str); //"xxxx67xxxx"', $str); //"xxxxjava6java7xxxx"$str2 = preg_replace($perg, '', $str); //"xxxx67xxxx"
$matchs输出结果:
array(2) { [0]幸福是什么意思=> array(2) { [0]=> string(5) "java6" [1]=> string(5) "java7" } [1]=> array(2) { [0]=> string(1) "6" [1]=> string(1) "7" }}
$str1输出结果:
string(18) "xxxxjava6java7xxxx"
$str2输出结果:
string(10) "xxxx67xxxx"
知道了preg_match_all的用法,对于上面的输出结果应该很清楚,[n]的后向引用。 [0]中保存的是匹配结果的全文,数组的个数=匹配到结果的个数,[1] 中保存的匹配结果中对应括号中匹配的结果(子组),…..[n]第n个括号中的匹配内容。
preg_replace 中的 \0,\1,也是对匹配结果的引用。
$str1 = preg_replace($perg, ‘\0长沙民政职业技术学院’, $str); //”xxxxjava6java7xxxx”, 用全文中的匹配结果进行对应替换
$str2 = preg_replace($perg, ‘\1’, $str); //R皮埃尔顾拜旦21;xxxx67xxxx”,用括号中的子结果进行对应的替换
我们对比知道,\0 的替换内容,是匹配全文的中内容,对应元素的替换。
$str = 'xxxxjava6java7xxxx';$perg = "/java(?:6|7)/"; preg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '$str = 'xxxxjava6java7xxxx';$perg = "/java(?:6|7)/"; preg_match_all($perg, $str, $matchs);$str1 = preg_rep文化产业管理专业lace($perg, '\0', $str); //"xxxxjava6java7xxxx"', $str); //"xxxxjava6java7xxxx"
$match 输出结果:
array(1) { [0]=> array(2) { [0]=> string(5) "java6" [1]=> string(5) "java7" }}
$str1输出结果:
string(18) "xxxxjava6java7xxxx"
对比例1中,我们发现没有括号匹配的结果,这就是我们说的非获取匹配,只匹配全本结果,不捕获括号中的子结果。
$str = 'xxxxjava6java7xxxx';$perg = "/java(?=6|7)/";preg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '$str = 'xxxxjava6java7xxxx';$perg = "/java(?=6|7)/";preg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '\0', $str); //"xxxxjava6java7xxxx"var_dump($matchs, $str1);die;', $str); //"xxxxjava6java7xxxx"var_dump($matchs, $str1);die;
输出结果:
array(1) { [0]=> array(2) { [0]=> string(4) "java" [1]=> string(4) "java" }}string(18) "xxxxjava6java7xxxx"
相比上面的我们匹配的结果中没有 6,7
$str = 'xxxxjava6java7xxxx';$perg = "/java(?!6)/"; //不匹配java6preg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '', $str); //"xxxxjava67xxxx"var_dump($matchs, $str1);die;
输出结果:
array(1) { [0]=> array(1) { [0]=> string(4) "java" }}string(14) "xxxxjava67xxxx"
这里匹配的到结果是java7,但是由于我们用了非获取匹配,就不存贮7,剩下的就是java了
主要:不管是怎么替换,如果我们只要用的是 \0(完整匹配结果) 中的结果进行替换,相当于匹配到了什么就替换掉原字符串中的什么,实际上原字符串没变化,
(?<=pattern) 反向匹配。(?<=j)a,匹配紧跟字母j后面的a,结果java6 java
(?<!pattern) 反向不匹配。(?<!j)a,不匹配紧跟字母j后面的a,结果java6 java
$str = 'xxxxjava6java7xxxx';$perg = "/(?<!6)java/"; //不匹配前端有6的jav梦想高中apreg_match_all($perg, $str, $matchs);$str1 = preg_replace($perg, '', $str); //"xxxx6java7xxxx"var_dump($matchs, $str1);die;
输出结果:
array(1) { [0]=> array(1) { [0]=> string(4) "java" }}string(14) "xxxx6java7xxxx"
总结:
正向预查,反向预查,就是方向不同。
正向预查时,具体字符串在左边,/java(?:6|7)/,从字符串开始向右查找;
反向则在右边: / (?<!j)a /,从字符串向反方向(左)查找。
本文发布于:2023-04-08 16:34:00,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/73df34109642741a3e34a8defff06c82.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:PHP正则之正向预查与反向预查讲解与实例.doc
本文 PDF 下载地址:PHP正则之正向预查与反向预查讲解与实例.pdf
留言与评论(共有 0 条评论) |