Php 从字符串中删除HTML标记和内部文本
我一直在使用Php 从字符串中删除HTML标记和内部文本,php,html,Php,Html,我一直在使用strip\u标记从字符串中删除HTML标记。但是,此方法仍然保留那些内部文本 如何从字符串中删除标记和内部文本 例如: Hello World <a href="/world">Remove me please!</a>, hello my friends. //expected result Hello world, hello my friends. 你好,世界,朋友们好。 //预期结果 你好,世界,你好,我的朋友们。 摘自PHP文档中关于stri
strip\u标记
从字符串中删除HTML标记。但是,此方法仍然保留那些内部文本
如何从字符串中删除标记和内部文本
例如:
Hello World <a href="/world">Remove me please!</a>, hello my friends.
//expected result
Hello world, hello my friends.
你好,世界,朋友们好。
//预期结果
你好,世界,你好,我的朋友们。
摘自PHP文档中关于strip\u tags()的注释。
你能举个例子吗?输入和期望输出。你考虑过吗?请发布一个你想要解析的HTML示例。还剩下什么?我想您需要使用DOM解析器来增加真正需要的部分;echo preg_replace(“#.*?#”和“$str”);这就是你想要的。
<?php
function strip_tags_content($text, $tags = '', $invert = FALSE) {
preg_match_all('/<(.+?)[\s]*\/?[\s]*>/si', trim($tags), $tags);
$tags = array_unique($tags[1]);
if(is_array($tags) AND count($tags) > 0) {
if($invert == FALSE) {
return preg_replace('@<(?!(?:'. implode('|', $tags) .')\b)(\w+)\b.*?>.*?</\1>@si', '', $text);
}
else {
return preg_replace('@<('. implode('|', $tags) .')\b.*?>.*?</\1>@si', '', $text);
}
}
elseif($invert == FALSE) {
return preg_replace('@<(\w+)\b.*?>.*?</\1>@si', '', $text);
}
return $text;
}
?>