XML学习之XSLT:三、XPath介绍
2013-02-21 20:41
225 查看
XPath上下文
XPath上下文(context)是一个非常重要的概念,上下文节点是正在被计算的节点,在多数情况下,上下文节点就是当前节点。
位置路径
位置路径(Local Path)有两种类型:相对位置路径和绝对位置路径。相对路径是有斜杠(/)分隔的一个或多个定位步骤序列组成,例:child::employees/child::employee[position()=1] 。绝对路径是有斜杠(/)和后面可选的相对位置路径组成,/表示根节点。如果/后面跟着相对位置路径,那么这个位置路径的计算式是从根节点开始的。例:/descendant::employee。
1.定位步骤
定位步骤包含3个部分,轴(axis)、节点测试(node test)、0个或多个谓词(predicate)。其中轴基于上下文节点来选择树状结构的不同区域。节点测试用于指定要选择的节点的名称或节点类型。谓词使用表达式,对通过轴和节点测试得到的节点集进行进一步的选择过滤。格式如:轴的名称::节点测试[谓词表达式] 。如:child::employee[position()=1],child是轴,employee是节点测试,[position()=1]是一个谓词。
(1)轴
轴用于在树状结构中选择一个初始的区域来应用节点测试和谓词。
(2)节点测试
节点测试时从轴中选择特定的节点或者节点类型。
指定节点的名称
从轴中选择与特定的名称相同的节点。例如:child::name,选择上下文节点的name子节点。
使用通配符星号(*)
使用*表示选择轴中所有的节点。例如:child::*,将选择上下文节点的所有子元素节点;attribute::*表示选择上下文节点的所有属性。
node()
表示选择轴中所有类型的节点。
text()
表示选择轴中所有的文本节点。例如,child::text(),将选择上下文节点的所有文本子节点。
comment()
表示选择轴中所有注释节点。
(3)谓词
对轴和节点测试得到的节点集进行过滤,生成一个新的节点集。谓词包含一个布尔表达式或者可以转化成布尔值的表达式。对于通过轴和节点测试得到节点集中的每一个节点,布尔表达式都将该节点作为上下文节点来计算,节点集中节点的数目作为上下文大小,以节点集中节点的位置作为上下文位置。
XPath上下文(context)是一个非常重要的概念,上下文节点是正在被计算的节点,在多数情况下,上下文节点就是当前节点。
位置路径
位置路径(Local Path)有两种类型:相对位置路径和绝对位置路径。相对路径是有斜杠(/)分隔的一个或多个定位步骤序列组成,例:child::employees/child::employee[position()=1] 。绝对路径是有斜杠(/)和后面可选的相对位置路径组成,/表示根节点。如果/后面跟着相对位置路径,那么这个位置路径的计算式是从根节点开始的。例:/descendant::employee。
1.定位步骤
定位步骤包含3个部分,轴(axis)、节点测试(node test)、0个或多个谓词(predicate)。其中轴基于上下文节点来选择树状结构的不同区域。节点测试用于指定要选择的节点的名称或节点类型。谓词使用表达式,对通过轴和节点测试得到的节点集进行进一步的选择过滤。格式如:轴的名称::节点测试[谓词表达式] 。如:child::employee[position()=1],child是轴,employee是节点测试,[position()=1]是一个谓词。
(1)轴
轴用于在树状结构中选择一个初始的区域来应用节点测试和谓词。
轴 | 含义 |
---|---|
ancestor | 上下文节点的祖先节点。包括上下文节点的父节点已经父节点的父节点,以此类推。如果上下文节点不是根节点,那么该轴总是包含跟节点。 |
ancestor-or-self | 上下文节点以及祖先节点。该轴总是包含跟节点。 |
atrribute | 上下文节点的属性节点。如果上下文节点没有属性,该轴为空。 |
child | 上下文节点的所有子节点。 |
descendant | 上下文节点的所有后代节点。包含上下文节点的子节点已经子节点的子节点,以此类推。不包含属性节点和名称空间节点。 |
descendant-or-self | 上下文节点以及后代节点。 |
parent | 上下文节点的父节点 |
self | 上下文节点本山 |
节点测试时从轴中选择特定的节点或者节点类型。
指定节点的名称
从轴中选择与特定的名称相同的节点。例如:child::name,选择上下文节点的name子节点。
使用通配符星号(*)
使用*表示选择轴中所有的节点。例如:child::*,将选择上下文节点的所有子元素节点;attribute::*表示选择上下文节点的所有属性。
node()
表示选择轴中所有类型的节点。
text()
表示选择轴中所有的文本节点。例如,child::text(),将选择上下文节点的所有文本子节点。
comment()
表示选择轴中所有注释节点。
(3)谓词
对轴和节点测试得到的节点集进行过滤,生成一个新的节点集。谓词包含一个布尔表达式或者可以转化成布尔值的表达式。对于通过轴和节点测试得到节点集中的每一个节点,布尔表达式都将该节点作为上下文节点来计算,节点集中节点的数目作为上下文大小,以节点集中节点的位置作为上下文位置。
相关文章推荐
- XML学习之XSLT:二、XPath介绍
- XML学习之XSLT:一、介绍和入门
- [推荐]学习XML / XPath / XSLT的好书
- [推荐]学习XML / XPath / XSLT的好书
- [推荐]学习XML / XPath / XSLT的好书
- [推荐]学习XML / XPath / XSLT的好书
- Xml,XPath,XSLTxue 学习方法
- 利用XSLT转换XML学习笔记
- XML Namespaces and How They Affect XPath and XSLT
- C#操作xml SelectNodes,SelectSingleNode总是返回NULL 与 xPath 介绍
- XML学习总结-XPATH技术-(二)
- 学习XPath和XSLT的好地方
- XML学习1_xpath路径表达式笔记
- xml学习笔记⑤xpath技术
- [XML]学习笔记(八)XSLT
- 一步步学习微软InfoPath2010和SP2010--第一章节--介绍InfoPath2010(7)--添加Products.xml到表单作为数据连接
- XML and XSL (XPath, XSLT and XSL-FO)
- C#操作xml SelectNodes,SelectSingleNode总是返回NULL 与 xPath 介绍
- SQL Server XML基础学习之<4>--XPath
- XML注入介绍--XXE,XEE,xpath等