XPath路径表达式怎么用 XPath节点选取方法

煙雲
发布: 2025-12-23 05:15:27
原创
326人浏览过
XPath是用于在XML/HTML中精准定位节点的语法,核心为从根或某节点出发按层级或条件逐步查找;常用绝对路径(如/html/body/div[1]/p)、相对路径(如//div/p)及轴(child::、descendant::等)与谓语(如[@class='title'])组合实现灵活选取。

xpath路径表达式怎么用 xpath节点选取方法

XPath 路径表达式是用来在 XML 或 HTML 文档中定位节点(元素、属性、文本等)的一套语法,核心是“从根或某节点出发,按层级或条件一步步找到目标”。用对了,就能精准提取数据;写错了,就容易匹配不到或选错范围。

基础路径写法:从根开始或相对定位

最常用的是绝对路径(以 / 开头)和相对路径(不以 / 开头):

  • /html/body/div[1]/p:从文档根开始,逐层指定元素,定位第一个 <div> 下的 <code><p></p> <div class="aritcle_card"> <a class="aritcle_card_img" href="/ai/1159"> <img src="https://img.php.cn/upload/ai_manual/000/000/000/175680127091510.png" alt="Musho"> </a> <div class="aritcle_card_info"> <a href="/ai/1159">Musho</a> <p>AI网页设计Figma插件</p> <div class=""> <img src="/static/images/card_xiazai.png" alt="Musho"> <span>90</span> </div> </div> <a href="/ai/1159" class="aritcle_card_btn"> <span>查看详情</span> <img src="/static/images/cardxiayige-3.png" alt="Musho"> </a> </div>
  • //div/p:双斜杠表示“任意层级”,匹配所有 <div> 元素下的直接子 <code><p></p>
  • .//span[@class='title']:点开头表示“从当前节点开始查找”,常用于嵌套解析时避免重写全路径
  • 常用节点选取方法:靠轴(axis)和谓语(predicate)

    真正灵活的选取靠的是“轴”描述方向、“谓语”加筛选条件:

    • child::(可省略):找直接子节点,如 div/child::a 等价于 div/a
    • descendant::(常用 // 替代):找所有后代,不限层级,如 //ul/descendant::li
    • following-sibling:::找后面同级的兄弟节点,如 h2/following-sibling::p[1] 取紧接在 <h2></h2> 后的第一个段落
    • 谓语写在方括号里,支持属性、位置、文本内容判断://input[@type='submit']//li[3]//a[text()='登录']

    实用技巧:处理常见难点

    实际用 XPath 抓网页或解析 XML 时,几个易错点要留意:

    • HTML 中的命名空间(如 SVG、XHTML)可能让 //div 失效,需先声明或用通配符 */div
    • 属性值含空格或动态 ID,别硬写完整值,改用包含匹配://div[contains(@class, 'btn-primary')]
    • 文本内容有换行缩进?用 normalize-space() 清理://p[normalize-space(text())='立即购买']
    • 多个条件组合用 andor//button[@type='submit' and contains(@class,'save')]

    基本上就这些。XPath 不复杂但容易忽略细节,多练几个真实 HTML 片段,比如找表格第二列、带 data-id 的按钮、或者某个 div 里最后一个非空段落,手感就上来了。

以上就是XPath路径表达式怎么用 XPath节点选取方法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
收藏 点赞
上一篇:什么是UDDI Web服务发现的XML规范 下一篇:XML数据库有哪些 原生XML数据库介绍
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
相关专题
更多>
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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