正则表达式偏题

WBOY
Libérer: 2016-06-13 11:16:43
original
770 Les gens l'ont consulté

正则表达式难题

本帖最后由 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 />?>
Copier après la connexion


得出的结果是

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 />}
Copier après la connexion



现在要问的是,如何操作使得使用{}中括号表示法,但是[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 />
Copier après la connexion

------解决方案--------------------
..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 />
Copier après la connexion

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

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

虽然规则有时不尽合理,但并不会因你而改变
Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal