Heim > Backend-Entwicklung > PHP-Tutorial > 正则表达式偏题

正则表达式偏题

WBOY
Freigeben: 2016-06-13 12:52:17
Original
923 Leute haben es durchsucht

正则表达式难题

本帖最后由 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 />
?>
Nach dem Login kopieren


得出的结果是

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 />
}
Nach dem Login kopieren



现在要问的是,如何操作使得使用{}中括号表示法,但是[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 />
Nach dem Login kopieren

------解决方案--------------------
..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 />
Nach dem Login kopieren

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

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

虽然规则有时不尽合理,但并不会因你而改变
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage