正则表达式,两个字符串之间的任意字符串,具有多次出现


Regular expression, any string between two strings with multiple occurences

我在PHP中使用一个简单的正则表达式来解析自定义模板

$row = preg_replace_callback(
    '/'^([^'^]+)'^/', create_function ('$m', 'global $fields_ar; return $fields_ar{$m[1]};'),
    $template
    );

基本上,两个^之间的所有内容都用相应的变量名称值替换,例如,如果$template是:

 <td>^title_source^ by ^author_source^<br/>

$fields_ar['title_source'] == 'my title' and  $fields_ar['author_source'] == 'my author'

$row变为:

<td>my title by my author<br/>

一切都很好,但我想更改分隔符;我想使用一个字符串,例如"sel3ction",而不是^,这有可能包含在其他两个^之间,但是:

$row = preg_replace_callback(
    '/sel3ction([^sel3ction]+)sel3ction/', create_function ('$m', 'global $fields_ar; return $fields_ar{$m[1]};'),
    $template
    );

不起作用;我确信问题出在消极方面。

有什么建议吗?

我知道这不是一种"干净"的方法,因为即使是最奇怪的字符串也可能很棘手,但目前我想尝试使用这种方法。如果您有更标准的解决方案,当然是受欢迎的。

谢谢!

当使用懒惰量词(?)匹配.时,您可以告诉您的表达式不要贪婪:

/sel3ction(.+?)sel3ction/

这告诉正则表达式引擎不要将.之后的内容(在本例中为"sel3ction")与可能匹配的其他内容进行匹配。