9.xpath概述

XPath 概述

XPath ( XML Path Language的简写)即为XML路径语言

作用:用于确定XML树结构中某一部分的位置。

XPath 技术基于XML的树结构,能够在树结构中遍历节点(元素、属性等)。

工作原理:XPath 使用路径表达式选取XML文档中的节点或者节点集,

这些路径表达式与常规的计算机文件系统中看到的路径非常相似,代表着从一个节点到另一个或者一组节点的顺序,并以“/”字符进行分隔。

注意: XPath 能够查询XML文档,也能够查询HTML文档。但是,它需要先借用lxml库技术将HTML文档转换为XML文档树对象,之后可以使用XPath语法查找此结构中的节点或元素。

XPath语法

表达式描述
nodename选取此节点的所有子节点。
//从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。
.选取当前节点。
选取当前节点的父节点。
/从根节点选取。
@选取属性。

选取节点的表达式应用

路径表达式结果
/bookstore/book从根节点bookstore开始,向下选取属于其所有book子节点
//book从任意位置开始,选取名称为book的所有节点

谓语(补充说明节点)

谓语指的是路径表达式的附加条件,这些条件都写在方括号中,表示对节点进行进一步筛选,用于查找某个特定节点或者包含某个指定值的节点
注意:

元素[表达式]谓语指的是路径表达式的附加条件,这些条件都写在方括号中,表示对节点进行进一步筛选,用于查找某个特定节点或者包含某个指定值的节点。
谓语表达式结果
/bookstore/book[1]选取属于 bookstore 子元素的第一个 book 元素。
/bookstore/book[last()]选取属于 bookstore 子元素的最后一个 book 元素。
/bookstore/book[last()-1]选取属于 bookstore 子元素的倒数第二个 book 元素。
/bookstore/book[position() < 3]选取最前面的两个属于 bookstore 元素的子元素的 book 元素。
//@lang使用@选取名称为lang的所有属性节点
//title[@lang]选取所有拥有名为 lang 的属性的 title 元素。
//title[@lang=‘eng’]选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
/bookstore/book[price>35.00]选取 bookstore 元素的所有 book 元素,且其中的 price 元素的值须大于 35.00。
/bookstore/book[price>35.00]/title选取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值须大于 35.00。

选取未知节点

通配符描述
*匹配任何元素节点。
@*匹配任何属性节点。
node()匹配任何类型的节点。

选取若干路径
通过在路径表达式中使用“|”运算符,您可以选取若干个路径。

路径表达式结果
//book/title 管道符//book/price选取 book 元素的所有 title 和 price 元素。
//title 管道符 //price选取文档中的所有 title 和 price 元素。
/bookstore/book/title管道符 //price选取属于 bookstore 元素的 book 元素的所有 title 元素,以及文档中所有的 price 元素。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值