目前我有以下情况:
我正在尝试“解析”一个文本,寻找占位符(他们的符号是“{…}”),稍后,我将用实际文本替换它们.
我正在尝试“解析”一个文本,寻找占位符(他们的符号是“{…}”),稍后,我将用实际文本替换它们.
我想到了正则表达式
$foo = "Hello World {foo{bar}} World Hello!"; $bar = array(); preg_match_all('@\{.+\}@U',$foo,$bar); var_dump($bar);
但这会回来
array(1) { [0]=> array(1) { [0]=> string(9) "{foo{bar}" } }
让它变得贪婪会导致:
array(1) { [0]=> array(1) { [0]=> string(10) "{foo{bar}}" } }
但我希望结果如下:
array(1) { [0]=> array(2) { [0]=> string(5) "{bar}" [1]=> string(10) "{foo{bar}}" } }
有没有办法在preg_match(_all)和正则表达式的帮助下达到这个目的?
或者我必须一次又一次地循环我的$bar,直到结果集中没有剩余的子语句?
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。