在php中使用正则表达式

发布于 2024-09-08 15:55:11 字数 167 浏览 4 评论 0原文

..(content).............
<A HREF="http://test.com/content" >test link </A>
...(continue content)...

我想删除包含内容的链接。还有链接之间的文本。

..(content).............
<A HREF="http://test.com/content" >test link </A>
...(continue content)...

I want to delete link with content. And also text between link.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

回梦 2024-09-15 15:55:12

我根本不会在这里使用正则表达式 - 而是 DOMDocument::loadHTML,然后 DOMDocument::getElementsByTagNameDOMNode::removeChild;最后 DOMDocument::saveHTML

I wouldn't use regex here at all - rather DOMDocument::loadHTML, then DOMDocument::getElementsByTagName and DOMNode::removeChild; finally DOMDocument::saveHTML

荒人说梦 2024-09-15 15:55:12

虽然可以使用正则表达式来做到这一点,但它们很容易出现问题。更强大的解决方案是使用 DOM 扩展 或其他 HTML 解析器来删除 a 有问题的元素。或者所有 a 元素,就此而言。如果您确实想使用正则表达式来执行此操作,则以下内容应该有效:

preg_replace('/<A (.*?)>(.*?)</A>/i', '', $data);

While regular expressions can be used to do this, they will be prone to problems. A more robust solution is using the DOM extension or another HTML parser to remove the a element in question. Or all a elements, for that matter. If you really want to do this with a regular expression, the following should work:

preg_replace('/<A (.*?)>(.*?)</A>/i', '', $data);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文