时间:2021-05-02
一、贪婪与非贪婪
什么叫贪婪,比如说要从字符串中<td>面包一</td><td>面包二</td>吃面包,本来你只可以吃面包一,可是你贪心,于是就把第一个<td>到最后一个</td>里面的两个面包取出来了,你想多吃点,非贪婪也就是你不贪吃了,就只吃面包一。
我们来看看正则里面是怎么贪婪的
? 1 2 3 4 <?php $str = '<td>面包一</td><td>面包二</td>'; preg_match('/<td>(.*)<\/td>/',$str,$res); print_r($res);结果:
Array
(
[0] => <td>面包一</td><td>面包二</td>
[1] => 面包一</td><td>面包二
)
0记录的是整个字符,1表示的是第一次匹配。
怎么来限制贪婪?
? 1 2 3 4 5 6 7 8 9 <?php $str = '<td>面包一</td><td>面包二</td>'; preg_match('/<td>(.*?)<\/td>/',$str,$res); print_r($res); Array ( [0] => <td>面包一</td> [1] => 面包一 )在修饰匹配次数的特殊符号后再加上一个 "?" 号,则可以使匹配次数不定的表达式尽可能少的匹配。
在PHP中还可以通过修饰符来实现,
? 1 2 3 4 <?php $str = '<td>面包一</td><td>面包二</td>'; preg_match('/<td>(.*)<\/td>/U',$str,$res); print_r($res);结果和上面一样。这就是修饰符U的作用
二、预搜索
预搜索是一个非获取匹配,不进行存储供以后使用。
1、正向预搜索 "(?=xxxxx)","(?!xxxxx)"
"(?=xxxxx)”:所在缝隙的右侧,必须能够匹配上 xxxxx 这部分的表达式,
? 1 2 3 4 <?php $str = 'windows NT windows 2003 windows xp'; preg_match('/windows (?=xp)/',$str,$res); print_r($res);结果:
Array
(
[0] => windows
)
这个是xp前面的windows,不会取NT和2003前面的。
格式:"(?!xxxxx)",所在缝隙的右侧,必须不能匹配 xxxxx 这部分表达式
? 1 2 3 4 <?php $str = 'windows NT windows 2003 windows xp'; preg_match_all('/windows (?!xp)/',$str,$res); print_r($res);结果:
Array
(
[0] => Array
(
[0] => windows 这个是nt前面的
[1] => windows 这个是2003前面的
)
)
从这里可以看出,预搜索不进行存储供以后使用。
与会存储的对比下。
? 1 2 3 4 <?php $str = 'windows NT windows 2003 windows xp'; preg_match_all('/windows ([^xp])/',$str,$res); print_r($res);结果:
Array
(
[0] => Array 全部模式匹配的数组
(
[0] => windows N
[1] => windows 2
)
[1] => Array 子模式所匹配的字符串组成的数组,通过存储取得。
(
[0] => N
[1] => 2
)
)
2、反向预搜索 "(?<=xxxxx)","(?<!xxxxx)"
"(?<=xxxxx)" :所在缝隙的 "左侧”能够匹配xxxxx部分。
? 1 2 3 4 <?php $str = '1234567890123456'; preg_match('/(?<=\d{4})\d+(?=\d{4})/',$str,$res); print_r($res);结果:
Array
(
[0] => 56789012
)
匹配除了前4个数字和后4个数字之外的中间8个数字
"(?<!xxxxx)":所在缝隙的“左侧”不能匹配xxxx部分。
结果:
Array
(
[0] => 234567890123456
)
三、preg和ereg的区别
PHP同时使用两套正则表达式规则,一套是由电气和电子工程师协会(IEEE)制定的POSIX Extended 1003.2兼容正则(事实上PHP对此标准的支持并不完善),另一套来自PCRE(Perl Compatible Regular Expression)库提供PERL兼容正则。 PHP5.3开始POSIX被删除了。
preg_match 比 ereg效率高。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
什么是正则表达式的贪婪与非贪婪匹配 如:Stringstr="abcaxc"; Patterp="ab*c"; 贪婪匹配:正则表达式一般趋向于最大长度
目录1.正则表达式基础1.1.简单介绍1.2.数量词的贪婪模式与非贪婪模式1.3.反斜杠的困扰1.4.匹配模式2.re模块2.1.开始使用re2.2.Match
本文实例总结了JS正则表达式贪婪和非贪婪模式。分享给大家供大家参考,具体如下:首先上一段js代码:try{str="abcdefgabcdefghijkl";r
前言本文主要给大家介绍了关于python使用正则表达式的非贪婪模式的相关内容,分享出来供大家参考学习,下面话不多说了,来一起详细的介绍吧。在正则表达式里,什么是
本文实例讲述了Python正则表达式非贪婪、多行匹配功能。分享给大家供大家参考,具体如下:一些regular的tips:1非贪婪flag>>>re.findal