好吧,我有一个字符串,如下所示:PHP的preg_replace需要改进
$disallowedBBC = 'abbr|acronym|anchor|bdo|black|blue|br|color|email|flash|font|ftp|glow|green|html|hr|img|iurl|li|list|ltr|url|quote';
而不是实际的字符串preg_replace
($message
变量)应该摆脱所有的英国广播公司代码,根据不准$disallowedBBC
变量:
$message = preg_replace("/\[($disallowedBBC)[^]]*](.*?)\[\/($disallowedBBC)\]/is", "$2", $message);
但是,出于某种原因,该[hr]
标签越来越过去,这的preg_replace。所以,在这种情况下:
$message = '[hr]Test';
它输出[hr]
标签,而应该将其删除。我的正则表达式有什么问题?
基本上...
,使其完全删除所有[HR]和/或[HR]测试[/小时]如何改变呢?但也需要摆脱其中某些Url [/ url]的实例。它应该从一个字符串中删除[color=red]
如下:[color=red]Testing
例如,它需要摆脱[{tag}]
,如果它有一个关闭标签[/{tag}]
,但如果没有关闭标签,它需要摆脱打开标签,反之亦然。它应该能够捕捉{}标签内,任何位于括号内为好,如:[quote author=Solomon time=7834783470]Just a quote here[/quote] Additional text here...
所以,这应该输出:Just a quote here Additional text here...
[^]应该是[^ \\] – walrii
你正则表达式匹配'[小时]测试[/小时]'而不是'[小时]测试' – xdazz
这并没有改变任何东西,仍然没有摆脱[hr]标签。 –