正则匹配的贪婪原则

WBOY
풀어 주다: 2016-06-06 20:19:39
원래의
1715명이 탐색했습니다.

问题:写了一个正则匹配,为什么每次只匹配一个中文,我写的是+,按照贪婪原则应该尽可能多的匹配。

<code>// $str 是个抓取到的html ,根据规则获取中文
$str = '...<span class="employment item" title="匹配中文字符">匹配中文字符</span>...';
preg_match('/<span.>/u', $str, $match);

var_dump($match[1]);

// 想要结果:匹配中文字符
// 输出结果: 字   </span.></code>
로그인 후 복사
로그인 후 복사

求大神指点


大神指点迷津之后:
做了修改,如下即可,尽可能的让前面的贪婪到固定的结束为止。 done

<code>// $str 是个抓取到的html ,根据规则获取中文
$str = '...<span class="employment item" title="匹配中文字符">匹配中文字符</span>...';
preg_match('/<span.>/u', $str, $match);

var_dump($match[1]);

// 想要结果:匹配中文字符
// 输出结果: 匹配中文字符   </span.></code>
로그인 후 복사
로그인 후 복사

回复内容:

问题:写了一个正则匹配,为什么每次只匹配一个中文,我写的是+,按照贪婪原则应该尽可能多的匹配。

<code>// $str 是个抓取到的html ,根据规则获取中文
$str = '...<span class="employment item" title="匹配中文字符">匹配中文字符</span>...';
preg_match('/<span.>/u', $str, $match);

var_dump($match[1]);

// 想要结果:匹配中文字符
// 输出结果: 字   </span.></code>
로그인 후 복사
로그인 후 복사

求大神指点


大神指点迷津之后:
做了修改,如下即可,尽可能的让前面的贪婪到固定的结束为止。 done

<code>// $str 是个抓取到的html ,根据规则获取中文
$str = '...<span class="employment item" title="匹配中文字符">匹配中文字符</span>...';
preg_match('/<span.>/u', $str, $match);

var_dump($match[1]);

// 想要结果:匹配中文字符
// 输出结果: 匹配中文字符   </span.></code>
로그인 후 복사
로그인 후 복사

因为前面的.+先贪婪了,它贪完了才轮到你想要的匹配组。而且后面还有个.+,所以你的匹配组还要给它留一个字。
结果就是前面贪婪匹配了一堆,后面匹配最后一个汉字。留给你的匹配组的就是倒数第二个汉字了。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿