微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 正则表达式量化捕获

PHP > preg_match("@/m(/[^/]+)+/t/?@", "/m/part/other-part/t", $m);
PHP > var_dump($m);
array(2) {
  [0]=>
  string(20) "/m/part/other-part/t"
  [1]=>
  string(11) "/other-part"
}
PHP > preg_match_all("@/m(/[^/]+)+/t/?@", "/m/part/other-part/t", $m);
PHP > var_dump($m);
array(2) {
  [0]=>
  array(1) {
    [0]=>
    string(20) "/m/part/other-part/t"
  }
  [1]=>
  array(1) {
    [0]=>
    string(11) "/other-part"
  }
}

通过上述示例,我希望捕获匹配/ part和/ other-part,遗憾的是regex / m(/ [^ /])/ t /?不像我期望的那样捕捉到两者.

此捕获不应仅限于匹配此样本,它应捕获捕获组的未定义重复次数;例如/米/部件/等部位/和另一个/多/吨

更新:
鉴于这是预期的行为,我的问题就是如何实现我的匹配?

解决方法:

试试这个:

preg_match_all("@(?:/m)?/([^/]+)(?:/t)?@", "/m/part/other-part/another-part/t", $m);
var_dump($m);

它给:

array(2) {
  [0]=>
  array(3) {
    [0]=>
    string(7) "/m/part"
    [1]=>
    string(11) "/other-part"
    [2]=>
    string(15) "/another-part/t"
  }
  [1]=>
  array(3) {
    [0]=>
    string(4) "part"
    [1]=>
    string(10) "other-part"
    [2]=>
    string(12) "another-part"
  }
}

//编辑

IMO做你想做的最好的方法是使用来自@stema的preg_match()并使用/爆炸结果得到你想要的部分列表.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐