NET框架下的Sytem.Xml.XPath命名空间提供了一系列的类,允许应用XPath数据模式查询和展示XML文档数据。

3.1XPath介绍

主要的目的是在xml1.0和1.1文档节点树种定位节点。XPath是一种表达式语言,他的返回值可能是节点、节点集合、原子值(文本),以及节点和原子值的混合等。

1、XPath节点

在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点)。树的根被称为文档节点或者根节点

<?xml version="1.0" encoding="ISO-8859-1"?>

<bookstore>

<book>
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year></year>
<price>29.99</price>
</book> </bookstore>
<bookstore> (文档节点)
<author>J K. Rowling</author> (元素节点)
lang="en" (属性节点)

基本值(或称原子值,Atomic value),基本值是无父或无子的节点。

J K. Rowling
"en"

项目是文本或者节点。

节点之间的关系:

父(Parent)每个元素以及属性都有一个父。子(Children)元素节点可有零个、一个或多个子。同胞(Sibling)拥有相同的父的节点。先辈(Ancestor)某节点的父、父的父,等等。后代(Descendant)某个节点的子,子的子,等等。

2、XPath语法

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

选取节点

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 元素。

4、XPath 轴

轴可定义相对于当前节点的节点集。

轴名称 结果
ancestor 选取当前节点的所有先辈(父、祖父等)。
ancestor-or-self 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。
attribute 选取当前节点的所有属性。
child 选取当前节点的所有子元素。
descendant 选取当前节点的所有后代元素(子、孙等)。
descendant-or-self 选取当前节点的所有后代元素(子、孙等)以及当前节点本身。
following 选取文档中当前节点的结束标签之后的所有节点。
namespace 选取当前节点的所有命名空间节点。
parent 选取当前节点的父节点。
preceding 选取文档中当前节点的开始标签之前的所有节点。
preceding-sibling 选取当前节点之前的所有同级节点。
self 选取当前节点。

位置路径表达式

位置路径可以是绝对的,也可以是相对的。

绝对路径起始于正斜杠( / ),而相对路径不会这样。在两种情况中,位置路径均包括一个或多个步,每个步均被斜杠分割:

绝对位置路径:

/step/step/...

相对位置路径:

step/step/...

每个步均根据当前节点集之中的节点来进行计算。

步(step)包括:

轴(axis)
定义所选节点与当前节点之间的树关系
节点测试(node-test)
识别某个轴内部的节点
零个或者更多谓语(predicate)
更深入地提炼所选的节点集

步的语法:

轴名称::节点测试[谓语]

实例

例子 结果
child::book 选取所有属于当前节点的子元素的 book 节点。
attribute::lang 选取当前节点的 lang 属性。
child::* 选取当前节点的所有子元素。
attribute::* 选取当前节点的所有属性。
child::text() 选取当前节点的所有文本子节点。
child::node() 选取当前节点的所有子节点。
descendant::book 选取当前节点的所有 book 后代。
ancestor::book 选择当前节点的所有 book 先辈。
ancestor-or-self::book 选取当前节点的所有 book 先辈以及当前节点(如果此节点是 book 节点)
child::*/child::price 选取当前节点的所有 price 孙节点。

XPath 表达式可返回节点集、字符串、逻辑值以及数字。

XPath 运算符

5、XPath函数

    XPath与XSLT、XQuery等共享函数库。函数库提供了功能丰富的各种内置函数。(XML函数)

3.2XPath数据模型

NET框架的XPath数据模型依赖于System.Xml.XPath命名空间中的XPathNavigator类,。XPathNavigator类是一个抽象类,提供基于光标的导航模型遍历XML文档的数据,它还允许你编辑XML文档。

能从任何一个实现IXPathNavigator接口的类获得XPathNavigatorD的实例。XmlDocument和XPathDocument均已实现这个接口。

System.Xml.XPath命名空间中的XPathDocument类使用XPath数据模型。提供了一个只读的代表一个xml文档的实例。

由于XmlDocument返回的XPathNavigator实例是可以编辑的,XPathDocument返回的实例是只读的。由于俩者都实现了IXPathNavigator接口,因而俩者都提供CreateNavigator方法用于创建XPahNavigator类的对象。

XPathDocument _doc = new XPathDocument(Application.StartupPath + @"\Customers.xml");
XPathNavigator _na = _doc.CreateNavigator();

1.应用XPathNavigator遍历xml文档

 //Move to root of document (<?xml version="1.0" encoding="utf-8" ?>)光标移动到文档的根处
_na.MoveToRoot();
_na.MoveToFirstChild();//Move the cursor to <customers> node光标移动到文档的customer节点处
na.MoveToNext();
_na.MoveToParent();

2、选择XML文档节点

选择文档中符合某些条件的某个或者某些节点。

   XPathNodeIterator _iterator = _na.Select(txtexpression.Text);
//XPathNodeIterator _iterator = _na.Select(_exp);
lblmessage.Text = "The expressions returned " + _iterator.Count + " nodes";
if (_iterator.Count > )
{
while (_iterator.MoveNext())
{
txtresult.Text += _iterator.Current.OuterXml;//Show the XML format of node(s)
}
}

Select方法接受XPah的表达式作为输入参数,返回XpahNodeIterator类的实例。

XpahNodeIterator类提供一些列的属性和方法允许你遍历返回的节点。在每个节点上,使用Current属性能给当前节点一个XPahtNavigator的引用。

然后可以调用调用XpahNodeIterator的任何方法和属性。SelectSingleNode 也支持XPath表达式返回一个XpahNodeIterator类型的对象。

该对象包括了符合XPah表达式条件的所有节点中的第一个节点。然后可以应用XpahNodeIterator访问该节点的属性和子节点。

除了上面的俩个方法外,还有三个方法

SelectChildren()方法=>节点名为参数,返回一个XpahNodeIterator类型对象,该对象包括当前节点的所有符合节点名的子节点。

SelectAncetors()方法=>节点名为参数,返回一个保包括当前节点的所有符合节点名的先辈节点的XpahNodeIterator类型的对象。

SelectDescendants()方法,节点名为参数,返回一个包括当前节点的所有符合节点名的后辈节点的XpahNodeIterator类型的对象。

在前面的例子中我们通过XPahNavigator类的GetAttribute()方法来访问元素属性 的值,但在文档如果元素具有多个属性,并且需要都访问时,XPahNavigator类

提供了三个函数方法来实现这个功能。MoveToAttribute()、MoveToFirstAttribute()和MoveToNextAttribute()..........

3、通过XPahtNavigator获得XmlReader和XmlWriter

XmlReader可以进一步读取返回的节点。通过调用XPathNavigator的ReadSubTree()方法获得XmlReader。

XmlWriter=》WriterSubTree()方法创建,该方法接受一个XmlWriter作为输入的参数,并将当前节点写入XmlWriter中。

XmlTextWriter _writer = new XmlTextWriter(txtfilepath.Text, null);
try
{
_na.WriteSubtree(_writer);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
writer.Close();
iswrite = true;
}
if (_id == txtID.Text)
{
XmlReader _reader = _na.ReadSubtree();
ShowDetail(_reader);
}

4、用XPahNavigator类编辑xml文档

实际上通常情况下,从XPahDocument获得XPahNavigator实例对象是只读的,因而不能用于编辑。而从XmlDocument获得对象可以用于编辑。通常用XPahNavigator的CanEdit的属性来检查XPathNavigator的实例是否可以用于编辑。是则返回true,否则为false。

 
 
 

XPath操作XML文档的更多相关文章

  1. 操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP)

    原文:操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP) 不管是用 PHP 还是 C#, 在操作 XML 的时候我们除了一个节点一个节点去取值之外, 还有一个非常方便的表达式, 就是 ...

  2. 操作xml文档的常用方式

    1.操作XML文档的两种常用方式: 1)使用XmlReader类和XmlWriter类操作 XmlReader是基于数据流的,占用极少的内存,是只读方式的,所以速度极快.只能采用遍历的模式查找数据节点 ...

  3. 使用DOM4J解析XML文档,以及使用XPath提取XML文档

    使用DOM4J解析XML文档 需要首先下载DOM4J工具包.这是个第三方工具包 在使用DOM4J解析的时候需要导入 DOM4J的JAR包 下载DOM4J工具包->在MyEclipse中新建lib ...

  4. C#XmlHelper操作Xml文档的帮助类

    using System.Xml; using System.Data; namespace DotNet.Utilities { /// <summary> /// Xml的操作公共类 ...

  5. [XML] C# XmlHelper操作Xml文档的帮助类 (转载)

    点击下载 XmlHelper.rar 主要功能如下所示 /// <summary> /// 类说明:XmlHelper /// 编 码 人:苏飞 /// 联系方式:361983679 // ...

  6. C# 操作XML文档 使用XmlDocument类方法

    W3C制定了XML DOM标准.很多编程语言中多提供了支持W3C XML DOM标准的API.我在之前的文章中介绍过如何使用Javascript对XML文档进行加载与查询.在本文中,我来介绍一下.Ne ...

  7. 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……

    大家有没有这样的感受,一涉及XML文档操作就得百度一遍.是不是非!常!烦!.各种类型,各种方法,更别提为了找到一个节点多费劲.本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果 ...

  8. C#操作XML文档---基础

    增查改删代码如下 public void CreateXML() { XmlDocument xml = new XmlDocument(); xml.AppendChild(xml.CreateXm ...

  9. 文档对象模型操作xml文档

    简介 :文档对象模型(DOM)是一种用于处理xml文档的API函数集. 2.1文档对象模型概述 按照W3C的定义,DOM是“一种允许程序或脚本动态地访问更新文档内容,结构和样式的.独立于平台和语言的规 ...

随机推荐

  1. Gdi+实用入门

    大部分是参照其它资料,然后加以自己的理解,那是什么,总结.算不得什么教程.......汗,自己看着就行了..如果别人能看那就更好了. 首先下载GDI+文件包,一个动态链接库,使用GDI+就是调用那个动 ...

  2. 高人ozhy111提供的下载资源

    特别是有很多手机方面的独创源代码,先记下来,有空挨个看一遍: http://download.csdn.net/user/ozhy111 比如:idtcpserver文件传输xe7PC端及手机端 ht ...

  3. 火车车次查询-余票查询--Api接口

    1.来自12306的火车车次数据 使用12306网站的接口,查询余票.此接口采集自 这里. 全国火车站代号字典,下载 . 火车票余票查询 http://dynamic.12306.cn/otsquer ...

  4. ExecutorService生命周期

    ExecutorService接口继承了Executor接口,定义了一些生命周期的方法 public interface ExecutorService extends Executor { void ...

  5. Javascript水平提升

    1,学习js分几个阶段,没入门,入门初学者,中级水平,高级水平,ppt水平. 2,没入门的如何学习? 我当初是先学jquery,有css和html基础,有css基础看jq的语法很简单,就是选择符,jq ...

  6. .net 与 javascript脚本的几种交互方法

    1.asp.net呼叫js Response.Write("<script language=javascript>"); Response.Write("a ...

  7. [YZOJ1579]&&[BZOJ2450]arr

    Description 给出3*n个数xi,要求构造三个长度为n的序列ai,bi,ci,使得满足下列条件: 1到3*n的每个数都在三个序列中的某个出现一次且仅一次: S=sum((x[ai]-x[bi ...

  8. 【pm2】

    告别node-forever,拥抱PM2 pm2及forever模块是目前较常用的nodejs进程守护模块,前者更常用些.功能也更强大(提供负载).其原理主要是pm2开启一个主进程,另行再开子进程运行 ...

  9. 在net安装程序中部署oracle客户端全攻略

    在net安装程序中部署oracle客户端全攻略 主要的是要做三件工作: 打包文件,写注册表,注册环境变量说明:我的oracle版本为9, 在2000 advanced server 上测试通过,可以正 ...

  10. ubuntu相关软件合集(持续更新中)

    本人使用的是Ubuntu-Kylin14.04,自带了日历.输入法.优客助手等易于上手的应用.省的每次安装完原生的系统再麻烦的安装,下面介绍默认应用外的相关常用软件: 一.Keylock Applic ...