小编给大家分享一下php正则表达式中贪婪与非贪婪的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
从网站建设到定制行业解决方案,为提供成都网站制作、成都网站建设服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。创新互联将不断加快创新步伐,提供优质的建站服务。
一、贪婪与非贪婪
什么叫贪婪,比如说要从字符串中
我们来看看正则里面是怎么贪婪的
面包一面包二 '; preg_match('/(.*)<\/td>/',$str,$res); print_r($res); 结果:
Array
(
[0] =>面包一 面包二
[1] => 面包一面包二
)0记录的是整个字符,1表示的是第一次匹配。
怎么来限制贪婪?
面包一面包二 '; preg_match('/(.*?)<\/td>/',$str,$res); print_r($res); Array ( [0] => 面包一 [1] => 面包一 )
在修饰匹配次数的特殊符号后再加上一个 "?" 号,则可以使匹配次数不定的表达式尽可能少的匹配。
在PHP中还可以通过修饰符来实现,
面包一面包二 '; preg_match('/(.*)<\/td>/U',$str,$res); print_r($res); 结果和上面一样。这就是修饰符U的作用
二、预搜索
预搜索是一个非获取匹配,不进行存储供以后使用。
1、正向预搜索 "(?=xxxxx)","(?!xxxxx)"
"(?=xxxxx)”:所在缝隙的右侧,必须能够匹配上 xxxxx 这部分的表达式,
结果:
Array
(
[0] => windows
)这个是xp前面的windows,不会取NT和2003前面的。
格式:"(?!xxxxx)",所在缝隙的右侧,必须不能匹配 xxxxx 这部分表达式
结果:
Array
(
[0] => Array
(
[0] => windows 这个是nt前面的
[1] => windows 这个是2003前面的
))
从这里可以看出,预搜索不进行存储供以后使用。
与会存储的对比下。
结果:
Array
(
[0] => Array 全部模式匹配的数组(
[0] => windows N
[1] => windows 2
)[1] => Array 子模式所匹配的字符串组成的数组,通过存储取得。
(
[0] => N
[1] => 2
))
2、反向预搜索 "(?<=xxxxx)","(?
"(?<=xxxxx)" :所在缝隙的 "左侧”能够匹配xxxxx部分。
结果:
Array
(
[0] => 56789012
)匹配除了前4个数字和后4个数字之外的中间8个数字
"(?结果:
Array
(
[0] => 234567890123456
)三、preg和ereg的区别
PHP同时使用两套正则表达式规则,一套是由电气和电子工程师协会(IEEE)制定的POSIX Extended 1003.2兼容正则(事实上PHP对此标准的支持并不完善),另一套来自PCRE(Perl Compatible Regular Expression)库提供PERL兼容正则。 PHP5.3开始POSIX被删除了。
preg_match 比 ereg效率高。
以上是“php正则表达式中贪婪与非贪婪的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
文章标题:php正则表达式中贪婪与非贪婪的示例分析
文章位置:http://jkwzsj.com/article/gidged.html