使用 XPath 将 HTML 无序列表转换为多维数组

使用 xpath 将 html 无序列表转换为多维数组

本文档旨在指导开发者如何使用 PHP 的 DOMDocument 和 DOMXPath 类,将包含状态信息的 HTML 无序列表结构转换为结构化的多维数组。通过使用 XPath 查询和数据提取,可以将网页中类似物流跟踪信息的列表转换为易于处理的 JSON 格式数据,方便后续的数据分析和应用。

准备工作

首先,确保你的 PHP 环境已经安装并启用了 DOMDocument 和 DOMXPath 扩展。这两个扩展通常是 PHP 默认安装的一部分,但如果遇到问题,可能需要手动启用。

代码实现

以下代码演示了如何将 HTML 字符串转换为多维数组,并最终输出为 JSON 格式。

preserveWhiteSpace = false;    @$domd->loadHTML('' . $html, $flags);    $removeAnnoyingWhitespaceTextNodes = function (DOMNode $node) use (&$removeAnnoyingWhitespaceTextNodes): void {        if ($node->hasChildNodes()) {            for ($i = $node->childNodes->length - 1; $i >= 0; --$i) {                $removeAnnoyingWhitespaceTextNodes($node->childNodes->item($i));            }        }        if ($node->nodeType === XML_TEXT_NODE && !$node->hasChildNodes() && !$node->hasAttributes() && ! strlen(trim($node->textContent))) {            $node->parentNode->removeChild($node);        }    };    $removeAnnoyingWhitespaceTextNodes($domd);    return $domd;}$html = <<<HTML
  • Status: Objeto em trânsito - por favor aguarde
  • Data : 24/10/2021 | Hora: 12:04
  • Origem: Unidade de Tratamento - Jaboatao Dos Guararapes / PE
  • Destino: Agência dos Correios - Cuitegi / PB
  • Status: Objeto em trânsito - por favor aguarde
  • Data : 19/10/2021 | Hora: 00:03
  • Origem: Unidade de Logística Integrada - Curitiba / PR
  • Destino: Unidade de Tratamento - Recife / PE
  • Status: Fiscalização aduaneira finalizada
  • Data : 18/10/2021 | Hora: 23:35
  • Local: Unidade Operacional - Curitiba / PR
  • Status: Objeto recebido pelos Correios do Brasil
  • Data : 16/10/2021 | Hora: 11:45
  • Local: Unidade de Logística Integrada - Curitiba / PR
  • Status: Objeto postado
  • Data : 14/10/2021 | Hora: 20:30
  • Local: País - /
HTML;$domd=loadHTML_noemptywhitespace($html);$xp=new DOMXPath($domd);$extracted=[];foreach($xp->query("//div[contains(@class,'singlepost')]/ul") as $ul){ $ulData=[]; foreach($xp->query("./li", $ul) as $li){ $data = explode(":",$li->nodeValue, 2); $uldata[trim($data[0])] = trim($data[1]); } $extracted[]=$uldata;}echo json_encode_pretty($extracted);?>

代码解释:

立即学习“前端免费学习笔记(深入)”;

加载 HTML 并创建 DOMXPath 对象:使用 DOMDocument 加载 HTML 字符串。创建 DOMXPath 对象,用于执行 XPath 查询。使用 loadHTML_noemptywhitespace 函数加载HTML,该函数可以移除HTML中的空白节点,避免干扰XPath查询结果。使用 XPath 查询 ul 元素:$xp->query(“//div[contains(@class,’singlepost’)]/ul”) 使用 XPath 表达式选择所有 class 包含 singlepost 的 div 元素下的所有 ul 元素。循环遍历 ul 元素,提取数据:外层 foreach 循环遍历每个 ul 元素。内层 foreach 循环遍历每个 li 元素。explode(“:”,$li->nodeValue, 2) 使用冒号分割 li 元素的文本内容,得到键值对。trim() 函数用于去除键和值两端的空格。格式化 JSON 输出:json_encode_pretty() 函数用于格式化 JSON 输出,使其更易读。

输出结果:

[    {        "Status": "Objeto em trânsito - por favor aguarde",        "Data": "24/10/2021 | Hora: 12:04",        "Origem": "Unidade de Tratamento - Jaboatao Dos Guararapes / PE",        "Destino": "Agência dos Correios - Cuitegi / PB"    },    {        "Status": "Objeto em trânsito - por favor aguarde",        "Data": "19/10/2021 | Hora: 00:03",        "Origem": "Unidade de Logística Integrada - Curitiba / PR",        "Destino": "Unidade de Tratamento - Recife / PE"    },    {        "Status": "Fiscalização aduaneira finalizada",        "Data": "18/10/2021 | Hora: 23:35",        "Local": "Unidade Operacional - Curitiba / PR"    },    {        "Status": "Objeto recebido pelos Correios do Brasil",        "Data": "16/10/2021 | Hora: 11:45",        "Local": "Unidade de Logística Integrada - Curitiba / PR"    },    {        "Status": "Objeto postado",        "Data": "14/10/2021 | Hora: 20:30",        "Local": "País -  /"    }]

注意事项

HTML 结构: 此代码依赖于特定的 HTML 结构。如果 HTML 结构发生变化,XPath 表达式可能需要进行调整。错误处理: 在实际应用中,应该添加适当的错误处理机制,例如检查 DOMDocument::loadHTML() 是否成功加载 HTML,以及 DOMXPath::query() 是否返回了预期的结果。编码问题: 确保 HTML 字符串的编码与 PHP 脚本的编码一致,以避免出现乱码问题。通常建议使用 UTF-8 编码。XPath 表达式: 编写正确的 XPath 表达式是至关重要的。可以使用浏览器开发者工具或在线 XPath 测试工具来验证 XPath 表达式的正确性。数据清洗: 在提取数据后,可能需要进行进一步的数据清洗,例如去除多余的空格、转换日期格式等。

总结

本文档提供了一个使用 PHP 的 DOMDocument 和 DOMXPath 类将 HTML 无序列表转换为多维数组的示例。通过使用 XPath 查询和数据提取,可以将网页中的结构化数据转换为易于处理的格式。在实际应用中,需要根据具体的 HTML 结构和需求进行适当的调整和优化。

以上就是使用 XPath 将 HTML 无序列表转换为多维数组的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1268905.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 11:37:30
下一篇 2025年12月10日 11:37:41

相关推荐

  • PHP函数中高效返回MySQL多行数据与自定义文本的最佳实践

    本文详细阐述了如何在PHP函数中高效地返回MySQL查询的多行结果集,并结合自定义文本。核心方法包括将数据库连接对象作为参数传递,以及利用关联数组结构化地封装查询结果与自定义信息,确保函数返回的数据完整且易于访问。文章通过示例代码展示了如何实现这一功能,并提供了重要的注意事项和最佳实践,以提升代码的…

    2025年12月10日
    000
  • 如何从PHP函数中返回MySQL查询结果与自定义文本

    本文详细介绍了如何在PHP中创建一个函数,以高效且灵活地返回MySQL数据库的查询结果集以及自定义文本。通过传递数据库连接对象并使用关联数组作为函数的返回值,可以清晰地分离和管理不同类型的数据,避免了传统方法中数据覆盖和单一返回值的限制,从而提升了代码的可读性和维护性。 在PHP开发中,我们经常需要…

    2025年12月10日
    000
  • Laravel 中使用 AJAX GET 请求更新数据库

    本文介绍了如何在 Laravel 控制器中使用 AJAX GET 请求获取的数据来更新数据库,而无需在成功后进行额外的 AJAX 请求。重点在于理解如何正确处理 Paystack 支付验证后的数据,并将其安全地更新到用户表中。同时,也强调了 CSRF 令牌的重要性以及正确的数据赋值方式。 前端:支付…

    2025年12月10日
    000
  • 生成Excel文件在PHP中无法用Microsoft Excel打开的解决方案

    本文旨在解决使用PHP生成的Excel文件无法在Microsoft Excel中打开,但可以使用Chrome扩展程序打开的问题。通过分析常见原因,并提供修改Content-Type和使用PhpSpreadsheet库两种解决方案,帮助开发者正确生成并导出可以在Microsoft Excel中正常打开…

    2025年12月10日
    000
  • PHP命令如何运行带命令行参数的PHP脚本 PHP命令处理参数的实用操作指南

    运行带命令行参数的php脚本可通过$argv和$argc获取参数,也可使用getopt()处理复杂选项,1. 使用$argv遍历参数并解析键值对;2. 为可选参数设置默认值以增强灵活性;3. 利用getopt()支持短选项和长选项,简化参数处理;4. 通过检查–help或-h输出帮助信息…

    2025年12月10日
    000
  • PHP函数怎样让函数只在满足条件时返回值 PHP函数条件返回的入门应用技巧​

    在php中,要让函数在特定条件下才返回值,核心机制是使用条件语句控制return的执行。1. 可通过if语句将return包裹在条件块中,使返回值仅在条件为真时生效;2. 利用“早期退出”模式,在函数开头进行条件校验并立即返回错误状态,避免深层嵌套,提升代码可读性;3. 根据业务逻辑决定无返回值时的…

    2025年12月10日
    000
  • PHP curl_multi 并发请求性能优化指南

    本文深入探讨了PHP中利用curl_multi进行并发HTTP请求时常见的性能瓶颈及优化策略。针对curl_multi_select函数在PHP中可能存在的非阻塞行为和超时参数不生效的问题,文章详细阐述了如何构建健壮的双循环结构来高效管理并发请求,避免不必要的等待时间,确保请求处理流程尽可能快地完成…

    2025年12月10日
    000
  • 解决Laravel Jetstream与AWS SES沙盒模式下的发件人地址限制

    在使用Laravel Jetstream的密码重置功能与AWS SES沙盒模式集成时,常遇到因SES要求发件人地址必须验证而导致邮件发送失败的问题。本文将深入探讨此问题,解释为何常见的配置尝试(如设置MAIL_FROM_ADDRESS或SES Source选项)无效,并揭示AWS SES沙盒模式下对…

    2025年12月10日
    000
  • PHP命令怎样在后台运行PHP脚本 PHP命令后台执行的实用操作方法

    使用nohup、screen或tmux可让PHP脚本在后台持续运行。首先,nohup结合&amp;amp;amp;符号能简单实现后台执行并避免终端关闭导致中断,但需注意输出重定向以防日志膨胀;其次,screen和tmux作为终端复用工具,支持会话分离与重连,适合复杂任务管理与多任务并行,提供…

    2025年12月10日
    000
  • 解决Laravel Jetstream与AWS SES发送邮件地址限制问题

    本文旨在解决Laravel Jetstream应用在使用AWS SES沙盒模式发送密码重置邮件时遇到的发送方地址验证问题。核心问题在于SES沙盒模式对发件人和收件人身份的严格限制。通过详细分析问题根源、常见尝试的局限性,并阐明最终解决方案——申请AWS SES生产访问权限,帮助开发者顺利配置邮件发送…

    2025年12月10日
    000
  • PHP命令如何使用-s参数显示彩色语法高亮的脚本 PHP命令语法高亮的操作技巧

    使用php命令的-s参数可以直接生成php脚本的html格式语法高亮输出,便于快速检查代码结构或分享代码片段;执行php -s filename.php会输出带html标签和内联样式的代码,其中不同语法元素被赋予颜色,但终端默认无法解析该颜色,需通过重定向到html文件并在浏览器中打开以查看彩色效果…

    2025年12月10日
    000
  • PHP常用框架怎样实现缓存预热与失效策略 PHP常用框架缓存策略的技巧

    缓存预热是通过定时任务或事件驱动提前将高频数据加载到缓存中,避免请求直接冲击数据库;2. 缓存失效策略包括基于时间的ttl、事件驱动的标签失效和版本号机制,确保数据更新时缓存能及时失效或更新;3. 在php框架中可通过模型事件监听结合缓存标签实现精准失效,如laravel中产品更新时触发事件并清除对…

    2025年12月10日
    000
  • 使用 Laravel Blade 组件简化表格元素插入

    本文旨在介绍如何利用 Laravel Blade 组件来简化表格元素的插入,提高代码的可维护性和可读性。虽然组件的使用可能不会显著减少代码量,但它能够将重复使用的 HTML 片段封装起来,从而提高代码的组织性和可重用性。通过创建表格行组件,我们可以将表格行的 HTML 结构和逻辑封装在一个单独的文件…

    2025年12月10日
    000
  • Laravel Blade:利用组件高效构建可复用表格结构

    本文探讨如何在Laravel Blade中简化表格元素的插入与管理。针对重复性表格行代码的问题,我们将介绍如何利用Laravel Blade组件(Components)来封装可复用的HTML结构,实现代码的模块化、清晰化和高效维护。通过实例演示,读者将掌握创建和使用Blade组件的方法,从而优化前端…

    2025年12月10日
    000
  • Laravel Blade 中高效复用表格元素:组件化实践

    本文探讨如何在 Laravel Blade 中高效、简洁地复用表格元素,解决传统 @include 结合 @section 导致重复内容的问题。我们将详细介绍如何利用 Laravel 强大的 Blade 组件功能,创建可参数化的表格行组件,从而实现代码的高度模块化和可维护性,提升开发效率。 理解原问…

    2025年12月10日
    000
  • SQL数据聚合与排序:实现重复行求和与结果降序排列

    本文详细介绍了如何使用SQL进行数据聚合与排序。通过结合GROUP BY子句和SUM()聚合函数,可以高效地将数据库表中重复的记录进行合并,并对相关数值进行求和。随后,利用ORDER BY子句实现对聚合结果的自定义排序,从而清晰地展现汇总后的数据,例如计算每个实体的总分数或总数量,并按从大到小的顺序…

    2025年12月10日
    000
  • Symfony 怎么将RabbitMQ消息转数组

    答案:将Symfony中RabbitMQ消息转为数组需根据消息体格式选择反序列化方式,常见为JSON或PHP序列化;若为JSON,使用json_decode($messageBody, true)转换并校验错误;若为PHP序列化,使用unserialize()但需注意安全风险;其他格式则用对应解析器…

    2025年12月10日
    000
  • PHP命令怎样在执行时自动记录脚本的运行状态 PHP命令运行状态记录的操作指南

    最直接的方式是使用Monolog库记录PHP CLI脚本的运行状态,通过配置文件处理器和格式化器,捕获脚本生命周期中的关键事件、错误及性能数据,并结合try-catch、全局异常处理和关闭函数实现全面的日志记录与错误监控。 要在PHP命令执行时自动记录脚本运行状态,最直接的方式是利用PHP内置的错误…

    2025年12月10日
    000
  • 如何在WordPress页面模板中实现全宽布局

    本教程旨在帮助您在WordPress中创建一个全宽页面模板,解决侧边栏意外显示的问题。我们将检查模板代码,确认侧边栏调用方式,并提供避免重复侧边栏显示的解决方案,确保您的页面呈现出预期的全宽效果。 在WordPress中创建全宽页面模板,通常意味着你希望移除页面上的侧边栏,让内容占据整个页面宽度。然…

    2025年12月10日
    000
  • 解决 macOS 12 上 Apache HTTPD 无法解析 PHP8 的问题

    本文旨在解决在 macOS 12 上升级 PHP 到 8 版本后,Apache HTTPD 无法正确解析 PHP 文件的问题。通过修改 Apache 的配置文件,添加 PHP 文件类型的解析规则,并重启 Apache 服务,即可使 Apache HTTPD 能够正确执行 PHP 代码。本文将提供详细…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信