本文将以一个非常简单的例子来说明如何使用C#访问一个XML文件并且读取其中的信息。例子本身并无任何实际意义,它只是简单的介绍了如何调用微软的XML标准以及如何运用到实际当中去。希望能够对初次接触C#或者未尝试过通过C#读取XML文件的读者有所启发。本文旨在抛砖引玉,希望能与更多的朋友交流和分享经验。
制作过程
1.
运行Visual Studio.NET,新建Visual C#.NET工程,这里取名为ReadXML。
2.
在解决方案资源管理器中,将Form1.cs改名为frmAuthor.cs(此项为可选)。
3.
将Form1的Name属性改为frmAuthor,Text属性改为Read XML Document,Font改为Verdana,9pt(此项为可选)。
4.
在窗体上添加四个控件:Lable控件(Name: lbl、Text: Author Name:)、ComboBox控件(Name: cboAuthor、DropDownStyle: DropDownList)、RichTextBox控件(Name: richtxt、Text:空)、Button控件(Name: btnShow、Text: Show Author’s Info)。调整各控件的位置,此时用户界面类似于下图:
5.
双击窗体,则IDE自动切换到代码编辑窗口,并自动添加了窗体载入方法frmAuthor_Load。在该方法内加入如下代码:
this.cboAuthor.Items.Add("张爱铃"); this.cboAuthor.Items.Add("福楼拜"); this.cboAuthor.Items.Add("马克·吐温");以上代码添加几条作者名字到ComboBox中去,这些作者的信息在XML文档中有对应项。
OK,到这里为止,我们所要做的一些程序初始化工作就已经完毕了。下面让我们来看看本例程所要展示的主要知识点。
在编写访问代码之前,让我们来看看XML文档的内容,如下:
<?xml version="1.0" encoding="gb2312" ?> <Author> <Zhang> <Intro>省略</Intro> </Zhang> <Fu> <Intro>省略</Intro> </Fu> <Mark> <Intro>省略</Intro> </Mark> </Author>
这是一个简单的XML文档,每个作者对应一条信息(Intro),共三条信息。我们要做的事情就是通过程序、按照XML文档的结构读取作者的简介,也就是Intro部分的内容。OK,下面就让我们来实现具体的代码。
1.
将以上XML文档(取名为Author.xml)放置在工程的根目录下(事实上放在任何地方均可以,但为了便于管理,这里就直接放在工程根目录下)。然后回到VS.NET,在frmAuthor.cs代码中头部添加以下代码:
using System.Xml;用于引用微软System.Xml命名空间。
2.
回到frmAuthor.cs[设计]页,双击Show Author’s Info按钮,则IDE自动添加btnShow_Click事件在frmAuthor.cs里。在btnShow_Click事件中,填写以下代码:
try { //Declaration string strAuthor = this.cboAuthor.Text.Trim(); string strXMLAuthor = ""; string strInfo; XmlDocument doc = new XmlDocument(); System.Xml.XPath.XPathNavigator nav; // = new System.Xml.XPath.XPathNavigator(); System.Xml.XPath.XPathNodeIterator iterator; // = new System.Xml.XPath.XPathNodeIterator(); //Validation if( strAuthor == "") { throw new ArgumentException("Author","You must select a author name!"); } //Load XML document doc.Load("..\\..\\Author.xml"); //Set nav object nav = ((System.Xml.XPath.IXPathNavigable)(doc)).CreateNavigator(); //Justification if( strAuthor == "张爱铃" ) strXMLAuthor = "Zhang"; else if( strAuthor == "福楼拜" ) strXMLAuthor = "Fu"; else if( strAuthor == "马克·吐温" ) strXMLAuthor = "Mark"; //Set node iterator iterator = nav.Select("Author/" + strXMLAuthor); //Move to the desired node iterator.MoveNext(); //Get the value of current node strInfo = iterator.Current.Value; //Display author's information this.richtxt.Text = strInfo; } catch(System.Exception err) { //Display Error MessageBox.Show(err.Message, "ERROR!"); }
3.
主要代码我们已经填写完毕。下面使用菜单“生成”>“生成解决方案”命令后,按F5即可运行测试程序是否正确了。
解释部分
1.
System.Xml命名空间
System.Xml 命名空间为处理 XML 提供基于标准的支持。支持的标准包括:
•
XML 1.0 - http://www.w3.org/TR/1998/REC-xml-19980210 - 包括 DTD 支持。
•
XML 命名空间 - http://www.w3.org/TR/REC-xml-names/ - 流级别和 DOM。
•
XSD 架构 - http://www.w3.org/2001/XMLSchema
•
XPath 表达式 - http://www.w3.org/TR/xpath
•
XSLT 转换 - http://www.w3.org/TR/xslt
•
DOM 级别 1 核心 - http://www.w3.org/TR/REC-DOM-Level-1/
•
DOM 级别 2 核心 - http://www.w3.org/TR/DOM-Level-2/
2.
XPathNavigator类
XPathNavigator 是基于 XPath 数据模型,并且提供了在任何数据存储区上实现 XPath 查询所需的方法。
XPathNavigator 提供对数据的只读随机访问。当前节点是指导航器定位在其上的节点。使用任何移动方法都可推进导航器并且属性反映当前节点的值。
3.
XPathNodeIterator 类
XPathNodeIterator 类是指在一组选定的节点上提供迭代程序。Iteractor一词源于Iterate(反复说, 重申, 重述),它会在选定的节点上进行迭代搜索,在我们的例子中,它会寻找符合条件的节点,并获得该节点上的值。
关于System.Xml命名空间及其子命名空间,可以查阅2002年后的MSDN Library,其中的“命名空间层次结构”一节中,我们可以清楚地看到各System.Xml命名空间的层次结构。
以上通过一个非常简单的例子来向大家展示如何利用C#及System.Xml命名空间直接访问一个XML文档。当然,本例程中的代码只是一种实现方法,代码也未经过整理和优化,这里只是希望能够通过这个例程给大家展示Visual C#的一个知识点而已