drzbc6003 2018-10-10 15:24
浏览 131
已采纳

PHP preg_replace:将文本中的所有锚标记替换为带有正则表达式的href值

I want to replace all anchor tags within a text with their href value, but my pattern does not work right.

$str = 'This is a text with multiple anchor tags. This is the first one: <a href="https://www.link1.com/" title="Link 1">Link 1</a> and this one the second: <a href="https://www.link2.com/" title="Link 2">Link 2</a> after that a lot of other text. And here the 3rd one: <a href="https://www.link3.com/" title="Link 3">Link 3</a> Some other text.';
$test = preg_replace("/<a\s.+href=['|\"]([^\"\']*)['|\"].*>[^<]*<\/a>/i",'\1', $str);
echo $test;

At the end the text should look like this:

This is a text with multiple anchor tags. This is the first one: https://www.link1.com/ and this one the second: https://www.link2.com/ after that a lot of other text. And here the 3rd one: https://www.link3.com/ Some other text.

Thank you very much!

  • 写回答

3条回答 默认 最新

  • dqw7121 2018-10-10 16:25
    关注

    Just don't.

    Use a parser instead.

    $dom = new DOMDocument();
    // since you have a fragment, wrap it in a <body>
    $dom->loadHTML("<body>".$str."</body>");
    $links = $dom->getElementsByTagName("a");
    while($link = $links[0]) {
        $link->parentNode->insertBefore(new DOMText($link->getAttribute("href")),$link);
        $link->parentNode->removeChild($link);
    }
    $result = $dom->saveHTML($dom->getElementsByTagName("body")[0]);
    // remove <body>..</body> wrapper
    $output = substr($result, strlen("<body>"), -strlen("</body>"));
    

    Demo on 3v4l

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 android报错 brut.common.BrutException: could not exec (exit code = 1)
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?