首页 > 代码库 > XPATH
XPATH
首先,XPATH是什么。官方的解释是:XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言。个人理解就是用路径的方式去描述XML的文档中的各个节点的一种方法。话不多说下面切入正题。
下面的例子以W3C官网上的这个XML文件为基础进行解析:
<?xml version="1.0" encoding="ISO-8859-1"?><bookstore><book> <title lang="eng">Harry Potter</title> <price>29.99</price></book><book> <title lang="eng">Learning XML</title> <price>39.95</price></book></bookstore>
1.路径表达式:
XPAT通过路径表达式对节点进行定位,基本的语法结构如下表:
路径表达式 | 描述 |
nodename | 选取该节点的所有子节点 |
/ | 从根节点开始选取 |
// | 不考虑位置,从匹配位置开始选取节点 |
. | 当前节点 |
.. | 当前节点的父节点 |
@ | 选取属性 |
例子:
表达式例子 | 含义 |
bookstore | bookstore的所有子节点 |
/bookstore | 选取根元素bookstore |
bookstore/book | bookstore节点下的所有book节点 |
//book | 不考虑路径,选择所有book节点 |
bookstore//book | 在bookstore的子路径下不考虑路径选择所有book节点 |
//@lang | 不考虑路径,选择所有名称为lang的属性 |
2 谓词
谓词用来定位某个特定位置的节点,或者包含某些值的节点,谓词一般在[]中
例子:
表达式 | 含义 |
/bookstore/book[1] | 在bookstore路径下的所有book节点中的第一个。注意下标从1开始 |
/bookstore/book[last()] | 在bookstore路径下的所有book节点中的最后一个 |
/bookstore/book[last()-1] | bookstore下的book节点中的倒数第二个 |
/bookstore/book[position()<3] | bookstore下的book节点中的第一个和第二个 |
//title[@lang] | 不考虑路径,包含属性lang的title节点 |
//title[@lang=‘en‘] | 不考虑理解,包含属性lang并且属性值是en的title节点 |
/bookstore/book[@price>50] | bookstore下的所有book节点中的包含price属性并且该属性值>50的节点集合 |
/bookstore/book[@price>50]/title | bookstore下的book下的title,其中book要求包含price属性并且值大于50 |
怎么样,例子非常清晰易懂吧。
3 选取未知节点
*用来匹配任意的
表达式 | 含义 |
/bookstore/* | bookstore下的所有节点 |
//* | 所有节点 |
//title[@*] | 所有带有属性的title节点 |
4 选取多个路径
可以使用|来选择多个路径: /bookstore/book[2] | /bookstore/book[2]/title
5 轴
轴即定义了和当前节点的某种关系的节点集合的表示方法:
轴名称 | 结果 |
---|---|
ancestor | 选取当前节点的所有先辈(父、祖父等)。 |
ancestor-or-self | 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。 |
attribute | 选取当前节点的所有属性。 |
child | 选取当前节点的所有子元素。 |
descendant | 选取当前节点的所有后代元素(子、孙等)。 |
descendant-or-self | 选取当前节点的所有后代元素(子、孙等)以及当前节点本身。 |
following | 选取文档中当前节点的结束标签之后的所有节点。 |
namespace | 选取当前节点的所有命名空间节点。 |
parent | 选取当前节点的父节点。 |
preceding | 选取文档中当前节点的开始标签之前的所有节点。 |
preceding-sibling | 选取当前节点之前的所有同级节点。 |
self | 选取当前节点。 |
轴的基本语法 轴::节点测试[谓语]
例子 | 结果 |
---|---|
child::book | 选取所有属于当前节点的子元素的 book 节点。 |
attribute::lang | 选取当前节点的 lang 属性。 |
child::* | 选取当前节点的所有子元素。 |
attribute::* | 选取当前节点的所有属性。 |
child::text() | 选取当前节点的所有文本子节点。 |
child::node() | 选取当前节点的所有子节点。 |
descendant::book | 选取当前节点的所有 book 后代。 |
ancestor::book | 选择当前节点的所有 book 先辈。 |
ancestor-or-self::book | 选取当前节点的所有 book 先辈以及当前节点(如果此节点是 book 节点) |
child::*/child::price | 选取当前节点的所有 price 孙节点。 |
6 运算符
XPATH支持逻辑运算和算数运算
运算符 | 描述 | 实例 | 返回值 |
---|---|---|---|
| | 计算两个节点集 | //book | //cd | 返回所有拥有 book 和 cd 元素的节点集 |
+ | 加法 | 6 + 4 | 10 |
- | 减法 | 6 - 4 | 2 |
* | 乘法 | 6 * 4 | 24 |
div | 除法 | 8 div 4 | 2 |
= | 等于 | price=9.80 | 如果 price 是 9.80,则返回 true。 如果 price 是 9.90,则返回 false。 |
!= | 不等于 | price!=9.80 | 如果 price 是 9.90,则返回 true。 如果 price 是 9.80,则返回 false。 |
< | 小于 | price<9.80 | 如果 price 是 9.00,则返回 true。 如果 price 是 9.90,则返回 false。 |
<= | 小于或等于 | price<=9.80 | 如果 price 是 9.00,则返回 true。 如果 price 是 9.90,则返回 false。 |
> | 大于 | price>9.80 | 如果 price 是 9.90,则返回 true。 如果 price 是 9.80,则返回 false。 |
>= | 大于或等于 | price>=9.80 | 如果 price 是 9.90,则返回 true。 如果 price 是 9.70,则返回 false。 |
or | 或 | price=9.80 or price=9.70 | 如果 price 是 9.80,则返回 true。 如果 price 是 9.50,则返回 false。 |
and | 与 | price>9.00 and price<9.90 | 如果 price 是 9.80,则返回 true。 如果 price 是 8.50,则返回 false。 |
mod | 计算除法的余数 | 5 mod 2 | 1 |
XPATH