正则表达式非贪婪模式和取反字符类的使用区别

有这么一个字符串:

<a href="#">one</a><a href="#">two</a>

我想匹配出 <a href="#">two</a>

于是我就写了

preg_match_all('/<a.*?>two<\/a>/',$str,$m);

得到的结果$m是

array(
  0=>'<a href="#">one</a><a href="#">two</a>'
)

我就纳闷了,.*?  不是指定了非贪婪模式吗?按我以前的理解就是 .* 不会包含 ? 后面的 > 字符,等效[^>]* 今天我才知道我错了。。 

这里贪婪模式并不是排除问号后面的字符,理论上的意思是尽可能少的重复,什么意思呢?再举个例子:

<a href="#">one</a><a href="#">two</a><a href="#">two</a>

这时候再用同样的正则去匹配会得到

array(
  0=>'<a href="#">one</a><a href="#">two</a>',
  1=>'<a href="#">two</a>'
)

其中的区别,无法用语言表达,心领神会吧。

转载于:https://my.oschina.net/cxz001/blog/819340

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值