> 백엔드 개발 > PHP 튜토리얼 > 正则表达式偏题

正则表达式偏题

WBOY
풀어 주다: 2016-06-13 11:16:43
원래의
795명이 탐색했습니다.

正则表达式难题

本帖最后由 xjl756425616 于 2013-03-07 21:02:34 编辑
<?php<br />$a="a11ba12b";<br />preg_match_all("/(a[^b]+b){2}/is",$a,$tmp);<br />var_dump($tmp);<br />?>
로그인 후 복사


得出的结果是

array(2) {<br />  [0]=><br />  array(1) {<br />    [0]=><br />    string(8) "a11ba12b"<br />  }<br />  [1]=><br />  array(1) {<br />    [0]=><br />    string(4) "a12b"<br />  }<br />}
로그인 후 복사



现在要问的是,如何操作使得使用{}中括号表示法,但是[1]中是= a11b,而不是 [1]=a12b,


------解决方案--------------------
\G?

<br />    $a="a11ba11b";<br />    preg_match_all("/\G(a[^b]+b){2}/i",$a,$tmp);<br />    var_dump($tmp);<br />
로그인 후 복사

------解决方案--------------------
..baoqian
貌似错的
------解决方案--------------------
不如指定贪婪模式
preg_match_all("/(a[^b]+b)+/iU",$a,$tmp);

坐等大牛回答。
------解决方案--------------------
这样? 你到底要干啥子吗

<br /><?php<br /><br />$a="a11ba12b";<br /><br />preg_match_all("/(a[^b]+b)a[^b]+b/is",$a,$tmp);<br /><br />var_dump($tmp);<br />
로그인 후 복사

------解决方案--------------------
引用:
我就是在研究大括号,哈哈

这有什么可研究的?规矩就是规矩
{ 最少/最多数量限定开始 
} 最少/最多数量限定结束 

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