XPath操作XML文档

时间:2022-02-03 20:16:28

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问题及解决方法 &lpar;C&num; 和 PHP&rpar;

    原文:操作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&num;XmlHelper操作Xml文档的帮助类

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

  5. &lbrack;XML&rsqb; C&num; XmlHelper操作Xml文档的帮助类 (转载)

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

  6. C&num; 操作XML文档 使用XmlDocument类方法

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

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

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

  8. C&num;操作XML文档---基础

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

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

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

随机推荐

  1. Js,alert出现乱码问题,赶紧记下来,额~~~

    原文 http://www.cnblogs.com/still-windows7/archive/2011/08/28/2156010.html 前些天还可以正常使用的js文件,在添加了一些东西后,其 ...

  2. 定制化jQuery

    毋庸置疑,jQuery很强大,很方便,但是......越来越臃肿,怎么办?,jquery只基于模块化开发的,可以通过工具定制jquery,选择你需要的模块即可. 下面这个网站可以帮你完成定制 http ...

  3. Linux常用保护机制

    Linux程序常见用的一些保护机制 一.NX(Windows中的DEP) NX:No-eXecute.DEP:Data Execute Prevention 也就是数据不可执行,防止因为程序运行出现溢 ...

  4. C语言 &&num;183&semi; C&plus;&plus;中map的用法详解

    转载自:http://blog.csdn.net/sunquana/article/details/12576729 一.定义   (1) map<string,   int>   Map ...

  5. 错误&Tab;1&Tab;error LNK2019&colon; 无法解析的外部符号 &quot&semi;public&colon; &lowbar;&lowbar;thiscall Distance&colon;&colon;Distance&lpar;int&rpar;&quot&semi; &lpar;&quest;&quest;0Distance&commat;&commat;QAE&commat;H&commat;Z&rpar;,该符号在函数 &lowbar;main 中被引用

    错误: 错误 1 error LNK2019: 无法解析的外部符号 "public: __thiscall Distance::Distance(int)" (??0Distanc ...

  6. selenium webdriver——XPath 定位

    baidu.html代码如下 ....<form id="form" class="fm" action="/s" name=&quo ...

  7. day6 装饰器总结

    装饰器:开放封闭原则,为一个函数加上新的功能,不改变原函数,不改变调用方式 def fun2(wtf): def fun3(): print('i am pythoner!!! ') wtf() re ...

  8. luogu2023 &lbrack;AHOI2009&rsqb;维护序列

    线段树加乘懒标记裸题. #include <iostream> #include <cstdio> using namespace std; typedef long long ...

  9. laravel如何利用数据库的形式发送通知

    具体实现需要分几步: 1.修改驱动为database; 2.创建database的queue表 3.创建任务sendMessage 4.创建发送逻辑dispatch 5.启动队列 接下来我们进行实操: ...

  10. django cookie session操作

    Cookie是什么? cookie说的直白点就是保存在用户浏览器端的一个键值对,举个例子,你现在登录了京东商城,你把浏览器关闭之后,你再打开京东,你还是可以对你的账户继续操作,已经购买的商品,订单都是 ...