【发布时间】:2015-10-27 06:30:04
【问题描述】:
有人很好地帮助我使用正则表达式进行非常具体的用途,但我现在唯一的问题是正则表达式仅替换匹配的 一个 实例,而不是所有 匹配(这是目标)。
我希望<SPAN> 的每个实例都带有“stylish-blue-button”类,可以在此处找到:
<span class="stylish-blue-button">
<span style="display:none;">[data-user="12345" data-userId="678910"]</span>
John Smith
<span style="display:none;">[/]</span>
</span>
...Blablabla some other text...
变成这样:
[data-user="12345" data-userId="678910"]John Smith[/] ...Blablabla some other text...
为此,我得到了这个 preg_replace :
preg_replace('~\[(data-user="\d+")\h+(data-userId="\d+")\]\s*(.+?)\s*\[/\]\s*(.*)~s', '<span $1 $2>$3</span>$4', trim(strip_tags($string)));
现在它可以工作了,非常棒,但它只替换了一个实例。
问题:我是否必须彻底改变/改变我的方法才能这样做,还是只是一个小的修改?
非常感谢。
【问题讨论】:
-
Regex 不是解析 HTML/XML 的正确工具,而是使用 DOMDocument
-
@Uchiha 虽然我完全同意,但由于我要做的第一件事是在用户生成的字符串上执行 strip_tags(),这不会破坏尝试解析 HTML 的目的吗?另外,我想,由于我的自定义降价将非常一致,这不会是最糟糕的事情。你还认为我应该进一步推动 DOM Document 吗?
标签: php regex preg-replace markdown