C#操作XML简要教程

转载 2007年09月18日 13:21:00
由于XML的易共享性等众多优点,XML技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。
  XML正快速成为从中间层传送数据到桌面的工具,由于XML的数据可以通过中间层代理与多种后端(数据库)源集成,目前绝大多数数据库制造商已全面支持XML技术,提供了各种强大功能处理XML数据。
  Microsoft的.NET围绕XML这一核心提供了一个强大而快速的开发工具——C#,它具有前所未有的高开发效率,特别是在XML编程方面。
  C#提供了许多相关类处理XML数据,如处理stream的类: XmlReader和XmlWriter; DOM的类:XmlNode、XmlDocument和XmlElement等; Xpath的类:XmlNavigator;XSLT的类:XslTransform。

 

  显示XML文件内容
  用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中,再用XmlDataDocument类的DataSet读XML的方法去读XML信息到DataSet中,DataSet再以DataView的方式赋给一个Web Form上的DataGrid,最后由DataBind显示数据,具体实现代码如下:
  using System.Xml;
  //处理XML必须加的Namespace,还需在References中加System.XML.Dll
  using System.IO;
  //读XML文件必须加的Namespace
  然后在Page_Load中加入如下代码:
  protected void Page_Load(object sender, EventArgs e){
  string datafile="guest.xml" ;
  //假设XML文件名为guest.xml
  StreamReader tyj=new StreamReader(Server.MapPath(datafile));
  XmlDataDocument datadoc = new XmlDataDocument();
  //创建该对象为了读取XML
  datadoc.DataSet.ReadXml(tyj);
  //读取guest.xml文件内容
  DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView;
  //设置DataGrid数据源
  DataGrid1.DataBind();
  //绑定
  datadoc=null ;
  //释放资源
  tyj.Close();}
  //释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用
  对应于显示用的Web Form中DataGrid的功能,我们需要增加下面的函数:
  protected void OnSelectName(object sender,EventArgs e) {
  Session["select_name"]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString();
  //把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用
  Response.Redirect("xml_manage.aspx");}
  //转到有增加删除功能的管理页
  Web Form加入以下代码:
  <asp:DataGrid id=DataGrid1 runat="server" onselectedindexchanged="OnSelectName" >
  <property name="Columns">
  <asp:buttoncolumn Text="选择" commandname="Select" />
  </property>
  代码中划线部分的作用是当按了“选择”按钮后,执行OnSelectName()中的程序,把选定的 DataGrid中某行中的一个单元中的值(Name)存入一个会话变量中,然后转到下一页。

 

  增加XML文件内容
  在Web Form中分别增加相应的四个Label(姓名,来自哪里,Email地址,留言内容)和四个TextBox和一个用于提交的Button,并为这button增加如下代码:
  string datafile = "guest.xml" ;XmlDocument xmldocument = new XmlDocument() ;
  xmldocument.Load(Server.MapPath(datafile)) ;
  //把guest.xml读到xmldocument中
  DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
  //最重要的类
  navigator.MoveToDocumentElement() ;
  navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, "Guest","","") ;//插入节点Guest  
    navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, "Name","","") ;
  navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Text,"Name","","") ;
  navigator.value="/Name.Text" ;
  //为该节点赋值
  navigator.MoveToParent() ;
  //返回父节点 Guest
  ……
  //使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等
  xmldocument.Save(Server.MapPath(datafile));
  //最后保存这个XML文档
  navigator=null ;
  xmldocument=null ;
  //释放XML文档,这样其他程序可以用它
  上述代码使用DocumentNavigator类增加元素和内容,注意使用后要释放资源。
  删除XML文件内容
  删除选定记录,对于你上面选择的节点,下面代码可查找到该节点并清除选中的信息:
  string datafile = "guest.xml" ;
  XmlDocument xmldocument = new XmlDocument() ;
  xmldocument.Load(Server.MapPath(datafile)) ;
  //把guest.xml读到xmldocument中
  DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
  navigator.MoveToDocumentElement() ;
  navigator.Select("/Guests/Guest[Name=""+Session["select_name"]+""]");
  //参数是XPath
  navigator.RemoveSelected();
  //执行删除
  xmldocument.Save(Server.MapPath(datafile));
  //最后保存这个XML文档
  navigator=null;
  //释放类
  xmldocument=null ;
  //释放XML文档,这样其他程序可以用它
  如需将XML文件中所有信息清除,使用“navigator.RemoveChildren();”语句即可实现。

 

  结 论
  综上可知,C#编写XML应用程序不但快捷而且方便,在编写ASP.NET数据库应用程序时,用XML文件替代一些小的Table,能减少许多数据库存取连接,也能让其他网络程序更易使用这些数据。
  目前XML的主要瓶颈在于文件系统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨大无比且修改量也较小,而浏览量巨大的话,使用XML方法将是很好的选择;相反,如数据量巨大,应考虑使用支持XML的数据库,无论你使用ADO+连接其他数据库,还是使用SQL server,C#中都有直接的类函数可让这些数据库中的信息直接和XML交互访问。

 

C#操作XML小结

一、简单介绍using System.Xml;//初始化一个xml实例XmlDocument xml=new XmlDocument();//导入指定xml文件xml.Load(path);xml.L...
  • xjj51296646
  • xjj51296646
  • 2009年06月04日 11:36
  • 80856

c#操作xml文档的通用类

using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu...
  • zhujunxxxxx
  • zhujunxxxxx
  • 2014年01月19日 13:22
  • 2082

Csharp读写XML

保存             XmlDocument xmlDoc = new XmlDocument();             xmlDoc.Load("Initialize.xml"); ...
  • shi__lin
  • shi__lin
  • 2014年02月27日 14:53
  • 1840

C#操作XML的完整例子——XmlDocument篇

这是一个用c#控制台程序下,  用XmlDocument 进行XML操作的的例子,包含了查询、增加、修改、删除、保存的基本操作。较完整的描述了一个XML的整个操作流程。适合刚入门.net XML操作的...
  • cds27
  • cds27
  • 2008年04月18日 17:18
  • 74461

C#操作数据库简介

如果一门程序设计语言不支持数据库操作的话,其很难在现在的世界中存活下来。 C#语言提供了丰富的数据库操作类库,极大地方便了对数据库的操作。在C#中,常用的有三种 访问数据库的模式分别为:SqlCli...
  • zhanghaoliangdehao
  • zhanghaoliangdehao
  • 2012年03月20日 11:36
  • 4987

c# xml操作类 比较齐全

using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu...
  • smartsmile2012
  • smartsmile2012
  • 2014年06月26日 14:17
  • 2768

C#操作XML简要教程(经典文章值的一读)

由于Xml的易共享性等众多优点,Xml技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。  Xml正快速成为从中间层传送数据到桌面的工具,由于Xml的数据可以通过...
  • zhanglei5415
  • zhanglei5415
  • 2007年08月07日 16:13
  • 1472

C#操作Xml通用工具类

  1个简单的处理XML的工具类代码1usingSystem;usingSystem.Xml;namespace WLERP.Common.Util{    ///     /// Xml 操作工具类...
  • bobo830
  • bobo830
  • 2011年04月20日 12:21
  • 2798

C#原生连接数据库并操作数据库的方法

最近想使用C#连一下SQL Server数据库,一搜网上资料,发现大部分是关于Linq的。但是我只想简简单单的连一下数据库,读取一下数据,用完就释放连接的这种,不想整一堆ORM的类文件到项目中,经过查...
  • Gane_Cheng
  • Gane_Cheng
  • 2016年08月17日 17:48
  • 1290

C# XML操作类 XmlHelper

using System.Xml; using System.Data; namespace DotNet.Utilities {     ///     /// Xml的操作公共类  ...
  • s10141303
  • s10141303
  • 2012年10月26日 00:13
  • 3723
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C#操作XML简要教程
举报原因:
原因补充:

(最多只允许输入30个字)