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 元素。 |