对于
xml,想必各位都比较了解,我也就不用费笔墨来描述它是什么了,我想在未来的Web开发中
xml一定会大放异彩,
xml是可扩展标记语言,使用它企业可以制定一套自己的数据格式,数据按照这种格式在网络中传输然后再通过XSLT将数据转换成用户期望的样子表示出来,这样便轻易的解决了数据格式不兼容的问题。用于Internet的数据传输,我想,这是
xml对于我们这些程序员最诱人的地方!
我们今天的主题不是论述
xml的好处,而是讨论在
C#中如何使用
xml。下面我们来了解一下使用程序访问
xml的一些基础理论知识。
访问的两种模型: 在程序中访问进而操作
xml文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新
xml文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对
xml文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。虽然是各有千秋,但我们也可以在程序中两者并用实现优劣互补嘛,呵呵,这是题外话了!我们今天主要讨论
xml的
读取,那我们就详细讨论一下流模型吧!
流模型中的变体: 流模型每次迭代
xml文档中的一个节点,适合于处理较大的文档,所耗内存空间小。流模型中有两种变体——“推”模型和“拉”模型。
推模型也就是常说的SAX,SAX是一种靠事件驱动的模型,也就是说:它每发现一个节点就用推模型引发一个事件,而我们必须编写这些事件的处理程序,这样的做法非常的不灵活,也很麻烦。
.NET中使用的是基于“拉”模型的实现方案,“拉”模型在遍历文档时会把感兴趣的文档部分从
读取器中拉出,不需要引发事件,允许我们以编程的方式访问文档,这大大的提高了灵活性,在性能上“拉”模型可以选择性的处理节点,而SAX每发现一个节点都会通知客户机,从而,使用“拉”模型可以提高Application的整体效率。在.NET中“拉”模型是作为
xmlReader类实现的,下面看一下该类的继承结构:
我们今天来讲一下该体系结构中的
xmlTextReader类,该类提供对
xml文件进行
读取的功能,它可以验证文档是否格式良好,如果不是格式良好的
xml文档,该类在
读取过程中将会抛出
xmlException异常,可使用该类提供的一些方法对文档节点进行
读取,筛选等操作以及得到节点的名称和值,请牢记:
xmlTextReader是基于流模型的实现,打个不恰当的比喻,
xml文件就好象水源,闸一开水就流出,流过了就流过了不会也不可以往回流。内存中任何时候只有当前节点,你可以使用
xmlTextReader类的Read()方法
读取下一个节点。好了,说了这么多来看一个例子,编程要注重实际对吧。看代码前先看下运行效果吧!
Example1按纽遍历文档
读取数据,Example2,Example3按纽得到节点类型,Example4过滤文档只获得数据内容,Example5得到属性节点,Example6按纽得到命名空间,Example7显示整个
xml文档,为此,我专门写一个类来封装以上功能,该类代码如下:
//---------------------------------
//
xmlReader类用于
xml文件的一般
读取操作,以下对这个类做简单介绍:
//
//Attributes(属性):
//listBox: 设置该属性主要为了得到客户端控件以便于显示所读到的文件的内容(这里是ListBox控件)
//
xmlPath: 设置该属性为了得到一个确定的
xml文件的绝对路径
//
//Basilic Using(重要的引用):
//System.
xml: 该命名空间中封装有对
xml进行操作的常用类,本类中使用了其中的
xmlTextReader类
//
xmlTextReader: 该类提供对
xml文件进行
读取的功能,它可以验证文档是否格式良好,如果不是格式 // 良好的
xml文档,该类在
读取过程中将会抛出
xmlException异常,可使用该类提供的
// 一些方法对文档节点进行
读取,筛选等操作以及得到节点的名称和值
//
//bool
xmlTextReader.Read():
读取流中下一个节点,当读完最后一个节点再次调用该方法该方法返回false
//
xmlNodeType
xmlTextReader.NodeType: 该属性返回当前节点的类型
//
xmlNodeType.Element 元素节点
//
xmlNodeType.EndElement 结尾元素节点
//
xmlNodeType.
xmlDeclaration 文档的第一个节点
//
xmlNodeType.Text 文本节点
//bool
xmlTextReader.HasAttributes: 当前节点有没有属性,返回true或false
//string
xmlTextReader.Name: 返回当前节点的名称
//string
xmlTextReader.Value: 返回当前节点的值
//string
xmlTextReader.LocalName: 返回当前节点的本地名称
//string
xmlTextReader.NamespaceURI: 返回当前节点的命名空间URI
//string
xmlTextReader.Prefix: 返回当前节点的前缀
//bool
xmlTextReader.MoveToNextAttribute(): 移动到当前节点的下一个属性
//------------------------------
namespace
xmlReading
{
using System;
using System.
xml;
using System.Windows.Forms;
using System.ComponentModel;
/// <summary>
///
xml文件
读取器
/// </summary>
public class
xmlReader : IDisposable
{
private string _
xmlPath;
private const string _errMsg = "Error Occurred While Reading ";
private ListBox _listBox;
private
xmlTextReader
xmlTxtRd;
#region
xmlReader 的构造器
public
xmlReader()
{
this._
xmlPath = string.Empty;
this._listBox = null;
this.
xmlTxtRd = null;
}
/// <summary>
/// 构造器
/// </summary>
/// <param name="_
xmlPath">
xml文件绝对路径</param>
/// <param name="_listBox">列表框用于显示
xml</param>
public
xmlReader(string _
xmlPath, ListBox _listBox)
{
this._
xmlPath = _
xmlPath;
this._listBox = _listBox;
this.
xmlTxtRd = null;
}
#endregion
#region
xmlReader 的资源释放方法
/// <summary>
/// 清理该对象所有正在使用的资源
/// </summary>
public void Dispose()
/// <summary>
/// 释放该对象的实例变量
/// </summary>
/// <param name="disposing"></param>
protected virtual void Dispose(bool disposing)
{
if (!disposing)
return;
if (this.
xmlTxtRd != null)
{
this.
xmlTxtRd.Close();
this.
xmlTxtRd = null;
}
if (this._
xmlPath != null)
{
this._
xmlPath = null;
}
}
#endregion
#region
xmlReader 的属性
/// <summary>
/// 获取或设置列表框用于显示
xml /// </summary>
public ListBox listBox
{
get
{
return this._listBox;
}
set
{
this._listBox = value;
}
}
/// <summary>
/// 获取或设置
xml文件的绝对路径
/// </summary>
public string
xmlPath
{
get
{
return this._
xmlPath;
}
set
{
this._
xmlPath = value;
}
}
#endregion
/// <summary>
/// 遍历
xml文件
/// </summary>
public void Each
xml()
{
this._listBox.Items.Clear();
this.
xmlTxtRd = new
xmlTextReader(this._
xmlPath);
try
{
while(
xmlTxtRd.Read())
{
this._listBox.Items.Add(this.
xmlTxtRd.Value);
}
}
catch(
xmlException exp)
{
throw new
xmlException(_errMsg + this._
xmlPath + exp.ToString());
}
finally
{
if (this.
xmlTxtRd != null)
this.
xmlTxtRd.Close();
}
}
/// <summary>
///
读取xml文件的节点类型
/// </summary>
public void Read
xmlByNodeType()
{
this._listBox.Items.Clear();
this.
xmlTxtRd = new
xmlTextReader(this._
xmlPath);
try
{
while(
xmlTxtRd.Read())
{
this._listBox.Items.Add(this.
xmlTxtRd.NodeType.ToString());
}
}
catch(
xmlException exp)
{
throw new
xmlException(_errMsg + this._
xmlPath + exp.ToString());
}
finally
{
if (this.
xmlTxtRd != null)
this.
xmlTxtRd.Close();
}
}
/// <summary>
/// 根据节点类型过滤
xml文档
/// </summary>
/// <param name="
xmlNType">
xmlNodeType 节点类型的数组</param>
public void FilterByNodeType(