-3

可能重复:
PHP Regex 获取 BBCode 标签之间的文本

我有这样的文字:

[lang_de]德语内容[/lang_de][lang_en]英语内容[/lang_en]。

我想替换开始和结束语言标签之间的所有[lang_en]文本[/lang_en]

这是我当前的正则表达式:

UPDATE wp_posts SET post_content = '" . addslashes(preg_replace("/[lang_en](.*)[\/lang_en]/", '', $row['post_content'])) . "' WHERE ID = " . $row['ID']

使用这个正则表达式,我没有得到有效的结果。它还替换 html 标签等。

什么是正确的正则表达式?

这是一个文本示例:

[lang_de]
<!--more-->
<div class="s-desc">
<br/>
Länge: 3:50 min | Tempo: 125 bpm
<p>
Text<br/>
</p>
<p>
<a href="#">LoFi-Version zum Testeinsatz in Ihrem Projekt hier downloaden</a>.     (Rechstklick-->Ziel speichern unter...)<br/>
Die Nutzung dieser LoFi-Version ist ausschließlich für Testzwecke erlaubt!
</p>
</div>
[/lang_de]


[lang_en]<!--more-->
<div class="s-desc">
<br/>
Length: 3:50 min | Tempo: 125 bpm
<p>
Text<br/>
</p>
<p>
<a href="#">Download a lofi-version to test with your project here</a>. (right-click-->save target as...)<br/>
The usage of this lofi-version is permitted for testing purposes only!
</p>
</div>
[/lang_en]

结果应如下所示:

<!--more-->
<div class="s-desc">
<br/>
Länge: 3:50 min | Tempo: 125 bpm
<p>
Text<br/>
</p>
<p>
<a href="#">LoFi-Version zum Testeinsatz in Ihrem Projekt hier downloaden</a>.     (Rechstklick-->Ziel speichern unter...)<br/>
Die Nutzung dieser LoFi-Version ist ausschließlich für Testzwecke erlaubt!
</p>
</div>
4

1 回答 1

-1
preg_replace("/\[lang_en](.*?)\[\/lang_en]/s", '', $text);
                            ^              ^
                          lazy             |
                                   '.' matches newlines as well

这里简单测试。

于 2012-06-30T15:15:41.710 回答