ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:20.66KB ,
资源ID:8571464      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8571464.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(XPath教程.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

XPath教程.docx

1、XPath教程 XPath教程XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历。XPath 是 W3C XSLT 标准的主要元素,并且 XQuery 和 XPointer 都构建于 XPath 表达之上。因此,对 XPath 的理解是很多高级 XML 应用的基础。开始学习 XPath!XPath 参考手册在 W3School,我们提供完整的 XPath 2.0、XQuery 1.0 和 XSLT 2.0 的内置函数参考手册。XPath 函数内容目录XPath 简介本章讲解 XPath 的概念。XPath 节点本章详细介绍 XPath

2、中不同类型的节点,以及节点之间的关系。XPath 语法本章讲解 XPath 的语法。XPath 轴本章讲解 XPath axes(轴)。XPath 运算符本章列出了可以用于 XPath 表达式的运算符。XPath 实例本章使用 books.xml 文档来演示一些 XPath 实例。XPath 摘要本文内容包括在本教程所学知识的一个总结,以及我们向你推荐的下一步应该学习的内容。XPath 参考手册XPath 函数XPath 2.0、XQuery 1.0 和 XSLT 2.0 的内置函数。XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航。

3、在学习之前应该具备的知识:在您继续学习之前,应该对下面的知识有基本的了解: HTML / XHTML XML / XML 命名空间如果您希望首先学习这些项目,请在我们的首页访问这些教程。什么是 XPath? XPath 使用路径表达式在 XML 文档中进行导航 XPath 包含一个标准函数库 XPath 是 XSLT 中的主要元素 XPath 是一个 W3C 标准XPath 路径表达式XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。XPath 标准函数XPath 含有超过 100 个内建的函数。这些函数用于字符串

4、值、数值、日期和时间比较、节点和 QName 处理、序列处理、逻辑值等等。XPath 在 XSLT 中使用XPath 是 XSLT 标准中的主要元素。如果没有 XPath 方面的知识,您就无法创建 XSLT 文档。您可以在我们的XSLT 教程中阅读更多的内容。XQuery 和 XPointer 均构建于 XPath 表达式之上。XQuery 1.0 和 XPath 2.0 共享相同的数据模型,并支持相同的函数和运算符。您可以在我们的XQuery 教程中阅读更多有关 XQuery 的知识。XPath 是 W3C 标准XPath 于 1999 年 11 月 16 日 成为 W3C 标准。XPath

5、 被设计为供 XSLT、XPointer 以及其他 XML 解析软件使用。您可以在我们的W3C 教程中阅读更多有关 XPath 标准的信息。在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点)。XPath 术语节点(Node)在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点。XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。请看下面这个 XML 文档: Harry Potter J K. Rowling 2005 29.99上面的XML文档中的节点例子: (文档节点)J

6、K. Rowling (元素节点)lang=en (属性节点) 基本值(或称原子值,Atomic value)基本值是无父或无子的节点。基本值的例子:J K. Rowlingen项目(Item)项目是基本值或者节点。节点关系父(Parent)每个元素以及属性都有一个父。在下面的例子中,book 元素是 title、author、year 以及 price 元素的父: Harry Potter J K. Rowling 2005 29.99子(Children)元素节点可有零个、一个或多个子。在下面的例子中,title、author、year 以及 price 元素都是 book 元素的子: H

7、arry Potter J K. Rowling 2005 29.99同胞(Sibling)拥有相同的父的节点在下面的例子中,title、author、year 以及 price 元素都是同胞: Harry Potter J K. Rowling 2005 29.99先辈(Ancestor)某节点的父、父的父,等等。在下面的例子中,title 元素的先辈是 book 元素和 bookstore 元素: Harry Potter J K. Rowling 2005 29.99后代(Descendant)某个节点的子,子的子,等等。在下面的例子中,bookstore 的后代是 book、title

8、、author、year 以及 price 元素: Harry Potter J K. Rowling 2005 29.99XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。XML 实例文档我们将在下面的例子中使用这个 XML 文档。 Harry Potter 29.99 Learning XML 39.95选取节点XPath 使用路径表达式在 XML 文档中选取节点。节点是通过沿着路径或者 step 来选取的。下面列出了最有用的路径表达式:表达式描述nodename选取此节点的所有子节点。/从根节点选取。/从匹

9、配选择的当前节点选择文档中的节点,而不考虑它们的位置。.选取当前节点。.选取当前节点的父节点。选取属性。实例在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:路径表达式结果bookstore选取 bookstore 元素的所有子节点。/bookstore选取根元素 bookstore。注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径!bookstore/book选取属于 bookstore 的子元素的所有 book 元素。/book选取所有 book 子元素,而不管它们在文档中的位置。bookstore/book选择属于 bookstore 元素的后代的所有

10、book 元素,而不管它们位于 bookstore 之下的什么位置。/lang选取名为 lang 的所有属性。谓语(Predicates)谓语用来查找某个特定的节点或者包含某个指定的值的节点。谓语被嵌在方括号中。实例在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:路径表达式结果/bookstore/book1选取属于 bookstore 子元素的第一个 book 元素。/bookstore/booklast()选取属于 bookstore 子元素的最后一个 book 元素。/bookstore/booklast()-1选取属于 bookstore 子元素的倒数第二个 bo

11、ok 元素。/bookstore/bookposition()35.00选取 bookstore 元素的所有 book 元素,且其中的 price 元素的值须大于 35.00。/bookstore/bookprice35.00/title选取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值须大于 35.00。选取未知节点XPath 通配符可用来选取未知的 XML 元素。通配符描述*匹配任何元素节点。*匹配任何属性节点。node()匹配任何类型的节点。实例在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:路径表达式结果/book

12、store/*选取 bookstore 元素的所有子元素。/*选取文档中的所有元素。/title*选取所有带有属性的 title 元素。选取若干路径通过在路径表达式中使用“|”运算符,您可以选取若干个路径。实例在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:路径表达式结果/book/title | /book/price选取 book 元素的所有 title 和 price 元素。/title | /price选取文档中的所有 title 和 price 元素。/bookstore/book/title | /price选取属于 bookstore 元素的 book 元素的所有

13、 title 元素,以及文档中所有的 price 元素。XML 实例文档我们将在下面的例子中使用此 XML 文档: Harry Potter 29.99 Learning XML 39.95XPath 轴轴可定义相对于当前节点的节点集。轴名称结果ancestor选取当前节点的所有先辈(父、祖父等)。ancestor-or-self选取当前节点的所有先辈(父、祖父等)以及当前节点本身。attribute选取当前节点的所有属性。child选取当前节点的所有子元素。descendant选取当前节点的所有后代元素(子、孙等)。descendant-or-self选取当前节点的所有后代元素(子、孙等)以

14、及当前节点本身。following选取文档中当前节点的结束标签之后的所有节点。namespace选取当前节点的所有命名空间节点。parent选取当前节点的父节点。preceding选取文档中当前节点的开始标签之前的所有节点。preceding-sibling选取当前节点之前的所有同级节点。self选取当前节点。位置路径表达式位置路径可以是绝对的,也可以是相对的。绝对路径起始于正斜杠( / ),而相对路径不会这样。在两种情况中,位置路径均包括一个或多个步,每个步均被斜杠分割:绝对位置路径:/step/step/.相对位置路径:step/step/.每个步均根据当前节点集之中的节点来进行计算。步(

15、step)包括:轴(axis)定义所选节点与当前节点之间的树关系节点测试(node-test)识别某个轴内部的节点零个或者更多谓语(predicate)更深入地提炼所选的节点集步的语法:轴名称:节点测试谓语实例例子结果child:book选取所有属于当前节点的子元素的 book 节点。attribute:lang选取当前节点的 lang 属性。child:*选取当前节点的所有子元素。attribute:*选取当前节点的所有属性。child:text()选取当前节点的所有文本子节点。child:node()选取当前节点的所有子节点。descendant:book选取当前节点的所有 book 后代

16、。ancestor:book选择当前节点的所有 book 先辈。ancestor-or-self:book选取当前节点的所有 book 先辈以及当前节点(如果此节点是 book 节点)child:*/child:price选取当前节点的所有 price 孙节点。XPath 表达式可返回节点集、字符串、逻辑值以及数字。XPath 运算符下面列出了可用在 XPath 表达式中的运算符:运算符描述实例返回值|计算两个节点集/book | /cd返回所有拥有 book 和 cd 元素的节点集+加法6 + 410-减法6 - 42*乘法6 * 424div除法8 div 42=等于price=9.80如

17、果 price 是 9.80,则返回 true。如果 price 是 9.90,则返回 false。!=不等于price!=9.80如果 price 是 9.90,则返回 true。如果 price 是 9.80,则返回 false。小于price9.80如果 price 是 9.00,则返回 true。如果 price 是 9.90,则返回 false。=小于或等于price大于price9.80如果 price 是 9.90,则返回 true。如果 price 是 9.80,则返回 false。=大于或等于price=9.80如果 price 是 9.90,则返回 true。如果 pric

18、e 是 9.70,则返回 false。or或price=9.80 or price=9.70如果 price 是 9.80,则返回 true。如果 price 是 9.50,则返回 false。and与price9.00 and price9.90如果 price 是 9.80,则返回 true。如果 price 是 8.50,则返回 false。mod计算除法的余数5 mod 21在本节,让我们通过实例来学习一些基础的 XPath 语法。XML实例文档我们将在下面的例子中使用这个 XML 文档:books.xml : Everyday Italian Giada De Laurentiis

19、2005 30.00 Harry Potter J K. Rowling 2005 29.99 XQuery Kick Start James McGovern Per Bothner Kurt Cagle James Linn Vaidyanathan Nagarajan 2003 49.99 Learning XML Erik T. Ray 2003 39.95在您的浏览器中查看此 books.xml 文件。加载 XML 文档所有现代浏览器都支持使用 XMLHttpRequest 来加载 XML 文档的方法。针对大多数现代浏览器的代码:var xmlhttp=new XMLHttpRequ

20、est()针对古老的微软浏览器(IE 5 和 6)的代码:var xmlhttp=new ActiveXObject(Microsoft.XMLHTTP)选取节点不幸的是,Internet Explorer 和其他处理 XPath 的方式不同。在我们的例子中,包含适用于大多数主流浏览器的代码。Internet Explorer 使用 selectNodes() 方法从 XML 文档中的选取节点:xmlDoc.selectNodes(xpath);Firefox、Chrome、Opera 以及 Safari 使用 evaluate() 方法从 XML 文档中选取节点:xmlDoc.evaluat

21、e(xpath, xmlDoc, null, XPathResult.ANY_TYPE,null);选取所有 title下面的例子选取所有 title 节点:/bookstore/book/title亲自试一试选取第一个 book 的 title下面的例子选取 bookstore 元素下面的第一个 book 节点的 title:/bookstore/book1/title亲自试一试这里有一个问题。上面的例子在 IE 和其他浏览器中输出不同的结果。IE5 以及更高版本将 0 视为第一个节点,而根据 W3C 的标准,应该是 1。为了解决 IE5+ 中 0 和 1 的问题,可以为 XPath 设置语

22、言选择(SelectionLanguage)。下面的例子选取 bookstore 元素下面的第一个 book 节点的 title:xml.setProperty(SelectionLanguage,XPath);xml.selectNodes(/bookstore/book1/title);亲自试一试选取所有价格下面的例子选取 price 节点中的所有文本:/bookstore/book/price/text()亲自试一试选取价格高于 35 的 price 节点下面的例子选取价格高于 35 的所有 price 节点:/bookstore/bookprice35/price亲自试一试选取价格高于 35 的 title 节点下面的例子选取价格高于 35 的所有 title 节点:/bookstore/bookprice35/title亲自试一试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1