十一章 xpath

什么是xpath

  1. XML路径语言,拥有在数据结构树中查找节点的能力
  2. 被开发者当作小型查询语言来使用
  3. XPath通过元素和属性进行导航

为什么学习xpath

  1. 支持html
  2. 比正则表达式简单
  3. 比正则表达式强大
  4. scrapy

xpath的基本概念

节点
父(Parent)
子(Children)
同胞(Sibling)
先辈(Ancestor)
后代(Descendant)
路径表达式

XPath 使用路径表达式在 XML 文档中选取节点

/
    从根节点选取。
//
    从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。
@
    选取属性。
谓语(Predicates)

备注/补充说明

/bookstore/book[1]
    选取属于 bookstore 子元素的第一个 book 元素。
/bookstore/book[last()]
    选取属于 bookstore 子元素的最后一个 book 元素。
/bookstore/book[last()-1]
    选取属于 bookstore 子元素的倒数第二个 book 元素。
/bookstore/book[position()<3]
    选取最前面的两个属于 bookstore 元素的子元素的 book 元素。
//title[@lang]
    选取所有拥有名为 lang 的属性的 title 元素。
//title[@lang='eng']
    选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
使用通配符
*
    匹配任何元素节点。
@*
    匹配任何属性节点。
选取若干路径
//book/title | //book/price
    选取 book 元素的所有 title 和 price 元素。
//title | //price
    选取文档中的所有 title 和 price 元素。
/bookstore/book/title | //price
    选取属于 bookstore 元素的 book 元素的所有 title 元素,以及文档中所有的 price 元素。

xpath的使用

安装lxml

pip install lxml

实例
  1. 获取所有的 <li> 标签
  2. 获取 <li> 标签的所有 class
  3. 获取 <li> 标签下 href 为 link1.html 的 <a> 标签
  4. 获取 <li> 标签下的所有 <span> 标签
  5. 获取 <li> 标签下的所有 class,不包括 <li>
  6. 获取最后一个 <li> 的 <a> 的 href
  7. 获取倒数第二个元素的内容
  8. 获取 class 为 bold 的标签名
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值