Xpath是XSLT(Extensible Stylesheet Language for Transformations,可扩展样式表语言)用到的表达式语法,用于定位XSLT文档中元素的位置。
Xpath定位寻址有两种语法:一种未经缩写的语法和一种缩写的语法。未经缩写的语法可以很清晰的表达出定位路径的含义,对于开始阶段学习理解一些概念非常有帮助。大多数开发人员都使用缩写的语法,这样开发效率更高。
一个定位步骤包含3个部分:轴(axis)、节点测试和谓词(predicate).轴和节点测试通过一个双冒号(::)来分开,他们都是必须 的。而谓词可选的,如果指定了谓词,那么它就必须紧接着节点测试,并且由中括号([])括起来。定位路径中的每一个定位步骤都是由一个斜杠(/)分开的。 如果节点的查找开始于根节点(绝对路径),第一个定位步骤也开始于一个斜杠。
下面写出一些常用的Xpath语法:
1. 含义:选择文档的根
未缩写的语法:/
缩写的语法:/
2. 含义:选择当前节点的子节点中的所有para元素节点
未缩写的语法:child::para
缩写的语法: para
3. 含义:选择根节点中的子节点的所有para元素节点(注意与上一个例子的区别)
未缩写的语法:/child::para
缩写的语法: /para
4. 含义:选择当前节点的后代节点中的所有para元素节点
未缩写的语法:descendant::para
缩写的语法: .//para
5. 含义:选择根节点的后代节点中所有para元素节点(注意与上一个例子的区别)
未缩写的语法:/descendant::para
缩写的语法: //para
6. 含义:选择当前节点的所有id属性
未缩写的语法:attribute::id
缩写的语法: @para
7. 含义:选择当前节点的所有属性
未缩写的语法:attribute::*
缩写的语法: @*
8. 含义:选择当前节点的子节点中的第五个chapter元素节点
未缩写的语法:child::chapter[position()=5]
缩写的语法: chapter[5]
9. 含义:选择当前节点的子节点中id值为this-one的所有chapter元素节点
未缩写的语法:child::chapter[attribute::id=”this-one”]
缩写的语法: chapter[@id=”this-one”]
10. 含义:选择属性值不为y的所有chapter元素节点
未缩写的语法:child::chapter[not(attribute::include=”y”)]
缩写的语法: chapter[@include =”y”]
11. 含义:选择根节点中的后代中的所有文本节点(也就是文档中所有的文本节点)
未缩写的语法:/descendant::text()
缩写的语法: //text()
12. 含义:选择当前节点的子节点中的num属性值为1,draft属性值为y的所有part节点
未缩写的语法:child::part[attribute::num=”1”] [attribute::draft=”y”]
缩写的语法: chapter[@num =”1”] [@draft =”y”]
13. 含义:选择当前节点的父节点,如果该父节点由include属性且值为y
未缩写的语法:parent::node()[attribute::include=”y”]
缩写的语法: .. [@include =”y”]
14. 含义:选择同时具有id属性和include属性的所有chapter元素节点(不管属性值是什么)
未缩写的语法:/descendant::chapter[attribute::id and attribute::include]
缩写的语法: //chapter[@id and @include]
Xpath定位寻址有两种语法:一种未经缩写的语法和一种缩写的语法。未经缩写的语法可以很清晰的表达出定位路径的含义,对于开始阶段学习理解一些概念非常有帮助。大多数开发人员都使用缩写的语法,这样开发效率更高。
一个定位步骤包含3个部分:轴(axis)、节点测试和谓词(predicate).轴和节点测试通过一个双冒号(::)来分开,他们都是必须 的。而谓词可选的,如果指定了谓词,那么它就必须紧接着节点测试,并且由中括号([])括起来。定位路径中的每一个定位步骤都是由一个斜杠(/)分开的。 如果节点的查找开始于根节点(绝对路径),第一个定位步骤也开始于一个斜杠。
下面写出一些常用的Xpath语法:
1. 含义:选择文档的根
未缩写的语法:/
缩写的语法:/
2. 含义:选择当前节点的子节点中的所有para元素节点
未缩写的语法:child::para
缩写的语法: para
3. 含义:选择根节点中的子节点的所有para元素节点(注意与上一个例子的区别)
未缩写的语法:/child::para
缩写的语法: /para
4. 含义:选择当前节点的后代节点中的所有para元素节点
未缩写的语法:descendant::para
缩写的语法: .//para
5. 含义:选择根节点的后代节点中所有para元素节点(注意与上一个例子的区别)
未缩写的语法:/descendant::para
缩写的语法: //para
6. 含义:选择当前节点的所有id属性
未缩写的语法:attribute::id
缩写的语法: @para
7. 含义:选择当前节点的所有属性
未缩写的语法:attribute::*
缩写的语法: @*
8. 含义:选择当前节点的子节点中的第五个chapter元素节点
未缩写的语法:child::chapter[position()=5]
缩写的语法: chapter[5]
9. 含义:选择当前节点的子节点中id值为this-one的所有chapter元素节点
未缩写的语法:child::chapter[attribute::id=”this-one”]
缩写的语法: chapter[@id=”this-one”]
10. 含义:选择属性值不为y的所有chapter元素节点
未缩写的语法:child::chapter[not(attribute::include=”y”)]
缩写的语法: chapter[@include =”y”]
11. 含义:选择根节点中的后代中的所有文本节点(也就是文档中所有的文本节点)
未缩写的语法:/descendant::text()
缩写的语法: //text()
12. 含义:选择当前节点的子节点中的num属性值为1,draft属性值为y的所有part节点
未缩写的语法:child::part[attribute::num=”1”] [attribute::draft=”y”]
缩写的语法: chapter[@num =”1”] [@draft =”y”]
13. 含义:选择当前节点的父节点,如果该父节点由include属性且值为y
未缩写的语法:parent::node()[attribute::include=”y”]
缩写的语法: .. [@include =”y”]
14. 含义:选择同时具有id属性和include属性的所有chapter元素节点(不管属性值是什么)
未缩写的语法:/descendant::chapter[attribute::id and attribute::include]
缩写的语法: //chapter[@id and @include]