我开发了一个类,它允许我控制许多BBCode标记和其他特殊格式,并且运行良好。我遇到的问题是内部标记与外部标记相同。例如,另一个引用中的引用如下所示:
[quote=Foo]Here is a quote:
[quote=Bar]Test[/quote]
Did that work?[/quote]问题是,正则表达式在查找外部开始引号的匹配项时,会查找内部结束/quote。
我是否必须拆分并逐行查找合适的匹配项,或者是否有一种优雅的方法来实现这一点?
下面是我如何做到这一点的一个小测试(还有更多,但从功能上讲这就是它所做的全部):
$desc = '[quote=Foo]Here is a quote:
[quote=Bar]Test[/quote]
Did that work?[/quote]';
$args = array(
'tid' => 1234
);
preg_match('`\[(quote)=?(.*?)\]((\r\n|\r|\n|.)+?)\[\/quote\]`i', $desc, $matches);
list($str, $tag, $match, $innertext) = $matches;
$params = explode(';', $match);
$name = array_shift($params);
$replacement = '<div class="quote">' . $name . '<span class="quote-text">' . $innertext . '</span></div>';
$string = str_replace($str, $replacement, $desc);当其他标签嵌套在其他标签中时,它们是正常的,只是like标签错误地找到了匹配。
发布于 2014-07-31 05:08:21
尝试使用贪婪的量词,并启用s dotall修饰符。
preg_match('~\[(quote)=?(.*?)\](.+)\[/quote\]~is', $desc, $matches)https://stackoverflow.com/questions/25046781
复制相似问题