0

0

XPath的//和/有什么区别

畫卷琴夢

畫卷琴夢

发布时间:2026-01-04 12:40:02

|

192人浏览过

|

来源于php中文网

原创

“/”表示严格父子路径,要求节点逐层精准嵌套;“//”表示全树扫描匹配,可跨任意层级查找元素。二者区别在于是否依赖DOM结构稳定性:/适用于固定模板和可控上下文,//适用于动态页面和全局搜索。

xpath的//和/有什么区别

“/”是严格父子路径,“//”是全树扫描匹配

简单说:/ 要求节点必须紧挨着、一层一层精准嵌套;// 则不管隔几层,只要存在就抓出来。这是 XPath 定位逻辑的根本分水岭。

  • /html/body/div:必须是从根开始, → 直接子 → 直接子
    ,中间不能跳、不能插兄弟节点
  • //div:整个 HTML 文档里所有
    标签,哪怕它藏在
    五层深,也能命中
  • 常见误用://ul/li/a 看似合理,但若实际结构是
    ,那 /a 就失效了——而 //a 仍能拿到
  • 什么时候该用 /,什么时候必须用 //

    不是“哪个更好”,而是“是否可控”。关键看 DOM 结构是否稳定、你是否掌握确切层级。

    • / 的典型场景:
       – 解析固定模板的后台管理页(如 /html/body/div[2]/main/form/input[@name="token"]
       – 配合 response.xpath() 后二次定位(如先取到某个
      ,再用 ./h2/text() 取它的直接标题)
    • // 的刚性需求:
       – 页面由 JS 动态渲染,结构不固定
       – 查找全局唯一语义元素(如 //button[contains(@class,"submit")]
       – Scrapy 中提取列表项内容(//div[@class="item"]/h3/text()),因为每个 item 是独立块,不需要从根算起
    • ./ 和 .// 容易被忽略的上下文差异

      当已经用 xpath() 定位到某个元素对象(比如一个

      ),后续路径前面加不加点(.),意义完全不同:
      • ./p:只在这个
        的**直接子

        DaGaoPeng(大高朋网团购程序)
        DaGaoPeng(大高朋网团购程序)

        大高朋团购系统是一套Groupon模式的开源团购程序,开发的一套网团购程序,系统采用ASP+ACCESS开发的团购程序,安装超简,功能超全面,在保留大高朋团购系统版权的前提下,允许所有用户免费使用。大高朋团购系统内置多种主流在线支付接口,所有网银用户均可无障碍支付;短信发送团购券和实物团购快递发货等。 二、为什么选择大高朋团购程序系统? 1.功能强大、细节完善 除了拥有主流团购网站功能,更特别支

        下载
        ** 中找(1 层深)
      • .//p:在这个
        **内部任意深度**的所有

        (可能嵌在
        里)
      • 错误现象举例:用 divs = response.xpath('//div[@class="list"]') 获取多个容器后,写 div.xpath('p/text()')(漏了 .)→ 实际变成从根找

        ,结果为空或错乱
      • divs = response.xpath('//div[@class="list"]')
        for div in divs:
            # ✅ 正确:在当前 div 内部找第一层 p
            title = div.xpath('./p/text()').get()
            # ✅ 正确:在当前 div 内部任意位置找所有 span
            tags = div.xpath('.//span[@class="tag"]/text()').getall()
            # ❌ 错误:这会脱离 div 上下文,去整个文档找 p
            wrong = div.xpath('p/text()').get()
        

        性能和健壮性的隐性权衡

        // 看似方便,但在大型页面或深层嵌套中,它会触发全树遍历;而 / 路径越短、越靠前,执行越快。但代价是:DOM 稍有变动(比如加了个 wrapper

        ),/html/body/... 就全挂。
        • 推荐策略:
           – 优先用 // 快速验证定位逻辑(开发期)
           – 上线前,对高频/关键元素,尝试收缩为 .// + 更稳定的属性(如 iddata-testid
           – 避免 //* 这类无差别通配,尤其在 Scrapy pipeline 中易拖慢解析
        • 真实坑点://div//p//div/p 多扫 N 层,如果页面有 50 个
          ,每个含 10 层嵌套,性能差距可达毫秒级——对爬虫吞吐量敏感时不可忽视

          XPath 的核心不是记符号,而是判断“我此刻是在找一棵树的某条确定枝干,还是在整片森林里搜某种叶子”。选错,轻则定位失败,重则让脚本在上线后静默失效。

相关文章

Python Flask如何返回一个XML响应

什么是WSRP(Web服务远程Portlet) WSRP XML标准

XPath语法怎么用 XPath路径表达式入门教程

Ruby Nokogiri库怎么用 Nokogiri解析HTML和XML教程

如何将不规范的HTML转换为格式良好的XML Tidy工具

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

上一篇:XSLT怎么实现字符串替换和拼接 下一篇:Java StAX解析器怎么用 StAX流式API解析XML教程

作者最新文章

热门AI工具

更多

相关专题

更多
html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

603

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

643

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

465

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

html是什么
html是什么

HTML是一种标准标记语言,用于创建和呈现网页的结构和内容,是互联网发展的基石,为网页开发提供了丰富的功能和灵活性。本专题为大家提供html相关的各种文章、以及下载和课程。

2872

2023.08.11

html字体大小怎么设置
html字体大小怎么设置

在网页设计中,字体大小的选择是至关重要的。合理的字体大小不仅可以提升网页的可读性,还能够影响用户对网页整体布局的感知。php中文网将介绍一些常用的方法和技巧,帮助您在HTML中设置合适的字体大小。

503

2023.08.11

html转txt
html转txt

html转txt的方法有使用文本编辑器、使用在线转换工具和使用Python编程。本专题为大家提供html转txt相关的文章、下载、课程内容,供大家免费下载体验。

308

2023.08.31

html文本框代码怎么写
html文本框代码怎么写

html文本框代码:1、单行文本框【<input type="text" style="height:..;width:..;" />】;2、多行文本框【textarea style=";height:;"></textare】。

422

2023.09.01

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

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

相关下载

更多

精品课程

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

共46课时 | 2.8万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.4万人学习

CSS教程
CSS教程

共754课时 | 18.1万人学习

最新文章

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

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