0

0

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

煙雲

煙雲

发布时间:2025-12-23 05:15:27

|

366人浏览过

|

来源于php中文网

原创

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

下载
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/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 里最后一个非空段落,手感就上来了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1946

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1168

2024.11.28

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.24

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.24

li是什么元素
li是什么元素

li是HTML标记语言中的一个元素,用于创建列表。li代表列表项,它是ul或ol的子元素,li标签的作用是定义列表中的每个项目。本专题为大家li元素相关的各种文章、以及下载和课程。

436

2023.08.03

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

AngularJS教程
AngularJS教程

共24课时 | 4.1万人学习

CSS教程
CSS教程

共754课时 | 42.1万人学习

最新文章

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

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