XSLT分析之一:XPath表达式
2006-04-12 21:25
288 查看
正在<看XSLT开发人员指南>,对里面的内容进行总结归纳
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是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]
相关文章推荐
- jQuery1.11源码分析(2)-----Sizzle源码中的正则表达式[原创]
- 日志分析代码实现(正则表达式)
- Atitit 表达式原理 语法分析 原理与实践 解析java的dsl 递归下降是现阶段主流的语法分析方法
- jQuery源码分析之jQuery中常用正则表达式分析
- C# 四则运算表达式解析器分析
- XPath and XSLT (II)
- 正则表达式匹配解析过程探讨分析(正则表达式匹配原理)
- HTML、 XML 、HTTP、 SOAP、 XSLT、 Xpath
- JQuery源码分析-02正则表达式-RegExp-常用正则表达式
- 语法分析表达式篇
- 一个简单的自顶向下语法分析(表达式求值)
- jQuery中的正则表达式分析 正则基础
- python使用正则表达式分析网页中的图片并进行替换的方法
- 关于四则运算表达式分析思路
- xpath路径表达式笔记
- Python常用正则表达式爬取网页信息及分析HTML标签总结
- 表达式计算: 分析与设计
- HBase中正则过滤表达式与JAVA正则表达式不一致问题的分析和解决
- C# WinForm开发系列 - XML/XSLT/XPATH
- 如何使用 XPath 表达式查询 XML