0

0

PHP中高效提取指定HTML标题及其紧邻段落的教程

聖光之護

聖光之護

发布时间:2025-12-02 11:03:54

|

903人浏览过

|

来源于php中文网

原创

PHP中高效提取指定HTML标题及其紧邻段落的教程

本教程详细介绍了如何使用php的domdocument和domxpath库,从复杂的html字符串中准确提取所有h3标题及其紧邻的第一个段落。文章强调了避免使用正则表达式解析html的重要性,并提供了一个结构清晰、包含示例代码和注意事项的专业解决方案,帮助开发者安全、高效地处理html内容。

HTML内容解析:提取指定标题及其紧邻段落

在Web开发中,我们经常需要从HTML内容中提取特定信息。一个常见的需求是获取某个特定级别的标题(例如

)及其紧随其后的第一个段落。虽然正则表达式在某些简单的文本匹配场景下表现出色,但在处理HTML这种具有复杂嵌套结构的标记语言时,使用正则表达式往往会导致代码脆弱、难以维护且容易出错。本文将介绍如何利用PHP内置的DOMDocument和DOMXPath类来安全、高效地实现这一目标。

为什么不推荐使用正则表达式解析HTML?

HTML是一种上下文无关文法,而正则表达式是处理正则文法的工具。尝试用正则表达式解析HTML,就像试图用一把扳手解决所有机械问题一样,虽然在某些简单情况下可能奏效,但面对稍微复杂一点的HTML结构(例如嵌套标签、属性、注释、不同风格的空白符等),正则表达式很快就会变得极其复杂,难以编写、调试和维护。更重要的是,它无法理解HTML的结构和DOM树,无法可靠地处理“下一个兄弟元素”或“父元素”这样的概念。

推荐方案:使用DOMDocument和DOMXPath

PHP提供了强大的DOM扩展,其中的DOMDocument类用于加载和解析HTML/XML文档,而DOMXPath类则允许我们使用XPath查询语言来导航和查找DOM树中的特定节点。这种方法不仅更健壮、更可靠,而且代码可读性也更高。

1. 加载HTML内容

首先,我们需要将HTML字符串加载到一个DOMDocument对象中。

立即学习PHP免费学习笔记(深入)”;

This is my title

This is a text right under my h1 title.

This is some more text under my h1 title

This is my level 2 heading

This is text right under my level 2 heading

First h3

First paragraph for the first h3

Second h3

First paragraph for the second h3

Third h3

First paragraph for the third h3

Second paragraph for the third h3

This is my level 2 heading

This is text right under my level 2 heading

TAG; $dom = new DomDocument(); // 使用 LIBXML_HTML_NOIMPLIED 和 LIBXML_HTML_NODEFDTD 标志来避免DOMDocument自动添加不必要的, , 等标签 // 这对于解析HTML片段非常有用 @$dom->loadHTML($html, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD); // 注意:loadHTML可能会因为HTML不规范而发出警告,使用@符号可以抑制这些警告,但更好的做法是进行错误处理。

在loadHTML方法中,我们使用了LIBXML_HTML_NOIMPLIED和LIBXML_HTML_NODEFDTD两个标志。它们的作用是告诉解析器不要自动添加缺失的、

、``等标签,这对于处理HTML片段而非完整文档时非常有用,可以避免生成不必要的额外结构。

2. 创建DOMXPath对象

DOMXPath对象允许我们对加载的DOM树执行XPath查询。

$xpath = new DOMXPath($dom);

3. 执行XPath查询并遍历结果

我们需要查询所有的

标签。XPath表达式//h3表示在文档的任何位置查找所有

元素。

获取到所有

白瓜AI
白瓜AI

白瓜AI,一个免费图文AI创作工具,支持 AI 仿写,图文生成,敏感词检测,图片去水印等等。

下载

元素后,我们可以遍历这些元素。对于每一个

元素,我们需要找到它紧邻的下一个兄弟元素,并检查它是否是

标签。

// 查询所有h3标签
$results = $xpath->query("//h3");
$extracted_data = [];

foreach ($results as $h3_node) {
    $heading_text = $h3_node->textContent;
    $paragraph_text = '';

    // 获取h3节点的下一个兄弟元素
    // nextElementSibling 属性返回元素的下一个兄弟元素(如果存在),忽略文本节点和注释节点
    $next_element = $h3_node->nextElementSibling;

    // 检查下一个元素是否存在且其标签名是否为'p'
    if ($next_element && 'p' === $next_element->nodeName) {
        $paragraph_text = $next_element->textContent;
    }

    $extracted_data[] = [
        'heading' => $heading_text,
        'paragraph' => $paragraph_text
    ];
}

// 打印提取的数据
foreach ($extracted_data as $item) {
    echo "

" . htmlspecialchars($item['heading']) . "

"; echo "

" . htmlspecialchars($item['paragraph']) . "

"; }

完整示例代码

This is my title

This is a text right under my h1 title.

This is some more text under my h1 title

This is my level 2 heading

This is text right under my level 2 heading

First h3

First paragraph for the first h3

Second h3

First paragraph for the second h3

Third h3

First paragraph for the third h3

Second paragraph for the third h3

This is my level 2 heading

This is text right under my level 2 heading

TAG; // 创建DOMDocument对象 $dom = new DomDocument(); // 加载HTML内容,并使用标志避免自动添加不必要的HTML结构 // @ 符号用于抑制loadHTML可能发出的关于HTML格式不规范的警告 @$dom->loadHTML($html, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD); // 创建DOMXPath对象,用于执行XPath查询 $xpath = new DOMXPath($dom); // 查询所有h3标签 $h3_nodes = $xpath->query("//h3"); $extracted_pairs = []; // 遍历所有h3节点 foreach ($h3_nodes as $h3_node) { $heading_text = $h3_node->textContent; $paragraph_text = ''; // 获取h3节点的下一个兄弟元素 // nextElementSibling 会跳过文本节点和注释节点,直接找到下一个元素节点 $next_element = $h3_node->nextElementSibling; // 检查下一个元素是否存在且其标签名是否为'p' if ($next_element && 'p' === $next_element->nodeName) { $paragraph_text = $next_element->textContent; } // 将提取到的标题和段落存储起来 $extracted_pairs[] = [ 'heading' => $heading_text, 'paragraph' => $paragraph_text ]; } // 按照期望的格式输出结果 foreach ($extracted_pairs as $pair) { echo "

" . htmlspecialchars($pair['heading']) . "

"; echo "

" . htmlspecialchars($pair['paragraph']) . "

"; } ?>

预期输出

First h3

First paragraph for the first h3

Second h3

First paragraph for the second h3

Third h3

First paragraph for the third h3

注意事项与总结

  1. 错误处理: loadHTML方法在处理格式不规范的HTML时可能会发出警告。在生产环境中,不建议简单地使用@抑制警告,而应该通过libxml_use_internal_errors(true)和libxml_get_errors()来捕获并处理这些错误,以提高程序的健壮性。
  2. nextElementSibling的局限性: nextElementSibling只查找下一个元素兄弟节点。如果HTML结构中在

    之间存在文本节点(例如空白符或注释),它会被跳过。如果需要考虑所有类型的节点,可以使用nextSibling,但之后需要额外判断nodeType。对于本例的需求,nextElementSibling是合适的选择。

  3. XPath的灵活性: XPath表达式非常强大,可以根据更复杂的条件来选择节点。例如,如果你需要选择具有特定类名的

    ,可以使用//h3[@class="my-class"]。

  4. 编码问题: 在处理包含非ASCII字符的HTML时,确保HTML内容和PHP脚本的编码一致(通常是UTF-8),以避免乱码。DOMDocument默认使用ISO-8859-1编码,如果HTML是UTF-8,你可能需要在加载前设置$dom->encoding = 'UTF-8';或在loadHTML后使用$dom->saveHTML()来获取正确的编码输出。
  5. 安全性: 在将提取到的文本重新输出到网页时,务必使用htmlspecialchars()或htmlentities()进行编码,以防止跨站脚本攻击(XSS)。

通过采用DOMDocument和DOMXPath,我们能够以一种结构化且安全的方式解析HTML,精确地定位和提取所需的数据,从而避免了正则表达式在处理HTML时的固有缺陷。这种方法是处理HTML内容的标准和推荐实践。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2599

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1624

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1510

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号