转:XPath路径表达式

XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。

XML 实例文档

我们将在下面的例子中使用这个 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>

选取节点

XPath 使用路径表达式在 XML 文档中选取节点。节点是通过沿着路径或者 step 来选取的。

下面列出了最有用的路径表达式:

 表达式  描述
 nodename  选取此节点的所有子节点
 /  从根节点选取
 //  从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
 .  选取当前节点
 ..  选取当前节点的父节点
 @  选取属性

实例

在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:

 路径表达式  结果
 bookstore  选取 bookstore 元素的所有子节点
 /bookstore

选取根元素 bookstore

注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径

 bookstore/book  选取所有属于 bookstore 的子元素的 book 元素。
 //book  选取所有 book 子元素,而不管它们在文档中的位置。
 bookstore//book  选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。
 //@lang  选取所有名为 lang 的属性。

谓语(Predicates)

谓语用来查找某个特定的节点或者包含某个指定的值的节点。

谓语被嵌在方括号中。

实例

在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:

 路径表达式  结果
 /bookstore/book[1]  选取属于 bookstore 子元素的第一个 book 元素。
 /bookstore/book[last()]  选取属于 bookstore 子元素的最后一个 book 元素
 /bookstore/book[last()-1]  选取属于 bookstore 子元素的倒数第二个 book 元素
 /bookstore/book[position()<3]  选取最前面的两个属于 bookstore 元素的子元素的 book 元素。
 //title[@lang]  选取所有拥有名为 lang 的属性的 title 元素。
 //title[@lang=‘eng‘]  选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
 /bookstore/book[price>35.00]  选取所有 bookstore 元素的 book 元素,且其中的 price 元素的值须大于 35.00。
 /bookstore/book[price>35.00]/title  选取所有 bookstore 元素中的 book 元素的 title 元素,且其中的 price 元素的值须大于 35.00。

选取未知节点

XPath 通配符可用来选取未知的 XML 元素。

 通配符  描述
 *  匹配任何元素节点
 @*  匹配任何属性节点
 node()  匹配任何类型的节点

实例

在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:

 路径表达式  结果
 /bookstore/*  选取 bookstore 元素的所有子节点
 //*  选取文档中的所有元素
 //title[@*]  选取所有带有属性的 title 元素。

选取若干路径

通过在路径表达式中使用“|”运算符,您可以选取若干个路径。

实例

在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:

 路径表达式  结果
 //book/title | //book/price  选取所有 book 元素的 title 和 price 元素
 //title | //price  选取所有文档中的 title 和 price 元素。
  /bookstore/book/title | //price  选取所有属于 bookstore 元素的 book 元素的 title 元素,以及文档中所有的 price 元素。

转:XPath路径表达式,布布扣,bubuko.com

时间: 2024-11-03 22:26:23

转:XPath路径表达式的相关文章

XPath路径表达式笔记(转载)

简单说,xpath就是选择XML文件中节点的方法. 所谓节点(node),就是XML文件的最小构成单位,一共分成7种. - element(元素节点)- attribute(属性节点)- text (文本节点)- namespace (名称空间节点)- processing-instruction (处理命令节点)- comment (注释节点)- root (根节点) xpath可以用来选择这7种节点.不过,下面的笔记只涉及最常用的第一种element(元素节点),因此可以将下文中的节点和元素

Xpath路径表达式

转自:http://www.ruanyifeng.com/blog/2009/07/xpath_path_expressions.html 简单说,xpath就是选择XML文件中节点的方法. 所谓节点(node),就是XML文件的最小构成单位,一共分成7种. - element(元素节点)- attribute(属性节点)- text (文本节点)- namespace (名称空间节点)- processing-instruction (处理命令节点)- comment (注释节点)- root

XPath详解

转载地址:http://www.cnblogs.com/fdszlzl/archive/2009/06/02/1494836.html XPath简介 XPath是W3C的一个标准.它最主要的目的是为了在XML1.0或XML1.1文档节点树中定位节点所设计.目前有XPath1.0和XPath2.0两个版本.其中Xpath1.0是1999年成为W3C标准,而XPath2.0标准的确立是在2007年.W3C关于XPath的英文详细文档请见:http://www.w3.org/TR/xpath20/ 

XPath 详解,总结

XPath简介 XPath是W3C的一个标准.它最主要的目的是为了在XML1.0或XML1.1文档节点树中定位节点所设计.目前有XPath1.0和XPath2.0两个版本.其中Xpath1.0是1999年成为W3C标准,而XPath2.0标准的确立是在2007年.W3C关于XPath的英文详细文档请见:http://www.w3.org/TR/xpath20/ . XPath是一种表达式语言,它的返回值可能是节点,节点集合,原子值,以及节点和原子值的混合等.XPath2.0是XPath1.0的超

【转】 HtmlAgilityPack使用——XPath注意事项

[转] HtmlAgilityPack使用--XPath注意事项 在使用HtmlAgilityPack这个开源的类库进行网页内容解析的时候是非常的方便(使用方法见另一篇博客<HTML解析:基于XPath的C#类库HtmlAgiliytyPack>),其基于XPath路径语法进行高效的选择文档节点,当发起请求获取了网页html文件的时候,解析的大部分工作量就落到了XPath路径表达式的书写了.本文测试在VS2010开发环境,.NetFramework 4.0 C#语言,使用的html如下: &l

Xpath—解决这个问题的良药

何为良药? 因为在XML中存在一些问题和缺陷,针对这些问题就产生了响应的解决方式.如: getElementById方法在解析XML时因为一些原因适不适合的: 首先XML中每一个元素节点不一定有id属性. 其次XML中的两个元素节点可能有同样的id属性.这样getElementById这种方法就不再能保证找到我们须要的唯一节点了. 针对这个原因Xpath就诞生了. Xpath是什么? Xpath是怎样产生的呢?它存在的必要是什么呢?接下来就让我们一一解答自己心中的疑问: 首先Xpath全称是XM

XPath 简介

XPath 简介 XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 XML 文档中通过元素和属性进行导航. 在学习之前应该具备的知识: 在您继续学习之前,应该对下面的知识有基本的了解: ·  HTML / XHTML ·  XML / XML 命名空间 如果您希望首先学习这些项目,请在我们的 首页 访问这些教程. 什么是 XPath? ·  XPath 使用路径表达式在 XML 文档中进行导航 ·  XPath 包含一个标准函数库 ·  XPath 是 XSLT 中的主要元

Xpath语法格式整理

经常在工作中会使用到XPath的相关知识,但每次总会在一些关键的地方不记得或不太清楚,所以免不了每次总要查一些零碎的知识,感觉即很烦又浪费时间,所以对XPath归纳及总结一下. 在这篇文章中你将能学习到: XPath简介 XPath 路径表达式详解 XPath在DOM,XSLT及XQuery中的应用 XPath简介 XPath 是W3C的一个标准.它最主要的目的是为了在XML1.0或XML1.1文档节点树中定位节点所设计.目前有XPath1.0和XPath2.0两个版 本.其中Xpath1.0是

XPath 语法规则

http://www.cnblogs.com/michaelsea/archive/2007/10/18/929230.html XPath is a language for finding information in an XML document. XPath is used to navigate through elements and attributes in an XML document. Xpath是一种能够在XML文档中寻找信息的语言.它通过XML文档中的元素和属性来进行