C#编程实现显示XML文件

开发 后端
这里介绍用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中。

C#语言编程有很多值得学习的地方,这里我们主要介绍C#编程实现显示XML文件,包括介绍在Web Form中分别增加相应的四个Label等方面。

C#编程实现显示XML文件

由于XML的易共享性等众多优点,XML技术越来越多地被应用于企业数据处理等领域,如应用于企业报表、新闻发布、会计数据处理等等。

XML正快速成为从中间层传送数据到桌面的工具,由于XML的数据可以通过中间层代理与多种后端(数据库)源集成,目前绝大多数数据库制造商已全面支持XML技术,提供了各种强大功能处理XML数据。

Microsoft的.NET围绕XML这一核心提供了一个强大而快速的开发工具——C#,它具有前所未有的高开发效率,特别是在XML编程方面。

C#提供了许多相关类处理XML数据,如处理stream的类: XmlReader和XmlWriter; DOM的类:XmlNode、XmlDocument和XmlElement等; Xpath的类:XmlNavigator;XSLT的类:XslTransform。

C#编程实现显示XML文件内容

用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中,再用 XmlDataDocument类的DataSet读XML的方法去读XML信息到DataSet中,DataSet再以DataView的方式赋给一个 Web Form上的DataGrid,最后由DataBind显示数据,具体实现代码如下:

  1. using System.Xml;  
  2. //处理XML必须加的Namespace,还需在References中加System.XML.Dll  
  3. using System.IO;  
  4. //读XML文件必须加的Namespace  
  5. 然后在Page_Load中加入如下代码:  
  6. protected void Page_Load(object sender, EventArgs e){  
  7. string datafile="guest.xml" ;  
  8. //假设XML文件名为guest.xml  
  9. StreamReader tyj=new StreamReader(Server.MapPath(datafile));  
  10. XmlDataDocument datadoc = new XmlDataDocument();  
  11. //创建该对象为了读取XML  
  12. datadoc.DataSet.ReadXml(tyj);  
  13. //读取guest.xml文件内容  
  14. DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView;  
  15. //设置DataGrid数据源  
  16. DataGrid1.DataBind();  
  17. //绑定  
  18. datadoc=null ;  
  19. //释放资源  
  20. tyj.Close();}  
  21. //释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用  
  22. 对应于显示用的Web Form中DataGrid的功能,我们需要增加下面的函数:  
  23. protected void OnSelectName(object sender,EventArgs e) {  
  24. Session["select_name"]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString();  
  25. //把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用  
  26. Response.Redirect("xml_manage.aspx");}  
  27. //转到有增加删除功能的管理页  
  28. Web Form加入以下代码:  
  29. <asp:DataGrid id=DataGrid1 runat="server" onselectedindexchanged="OnSelectName" >  
  30. <property name="Columns">  
  31. <asp:buttoncolumn Text="选择" commandname="Select" />  
  32. </property> 

代码中划线部分的作用是当按了“选择”按钮后,执行OnSelectName()中的程序,把选定的 DataGrid中某行中的一个单元中的值(Name)存入一个会话变量中,然后转到下一页。

增加XML文件内容

在Web Form中分别增加相应的四个Label(姓名,来自哪里,Email地址,留言内容)和四个TextBox和一个用于提交的Button,并为这button增加如下代码:

  1. string datafile = "guest.xml" ;XmlDocument xmldocument = new XmlDocument() ;  
  2. xmldocument.Load(Server.MapPath(datafile)) ;  
  3. //把guest.xml读到xmldocument中  
  4. DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;  
  5. //最重要的类  
  6. navigator.MoveToDocumentElement() ;  
  7. navigator.Insert(System.Xml.TreePosition.FirstChild, 
    XmlNodeType.Element, "Guest","","") ;//插入节点Guest  
  8.     navigator.Insert(System.Xml.TreePosition.FirstChild, 
    XmlNodeType.Element, "Name","","") ;  
  9. navigator.Insert(System.Xml.TreePosition.FirstChild, 
    XmlNodeType.Text,"Name","","") ;  
  10. navigator.Value=Name.Text ;  
  11. //为该节点赋值  
  12. navigator.MoveToParent() ;  
  13. //返回父节点 Guest  
  14. ……  
  15. //使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等  
  16. xmldocument.Save(Server.MapPath(datafile));  
  17. //最后保存这个XML文档  
  18. navigator=null ;  
  19. xmldocument=null ;  
  20. //释放XML文档,这样其他程序可以用它  
  21. 上述代码使用DocumentNavigator类增加元素和内容,注意使用后要释放资源。  
  22. 删除XML文件内容  
  23. 删除选定记录,对于你上面选择的节点,下面代码可查找到该节点并清除选中的信息:  
  24. string datafile = "guest.xml" ;  
  25. XmlDocument xmldocument = new XmlDocument() ;  
  26. xmldocument.Load(Server.MapPath(datafile)) ;  
  27. //把guest.xml读到xmldocument中  
  28. DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;  
  29. navigator.MoveToDocumentElement() ;  
  30. navigator.Select("/Guests/Guest[Name=""+Session["select_name"]+""]");  
  31. //参数是XPath  
  32. navigator.RemoveSelected();  
  33. //执行删除  
  34. xmldocument.Save(Server.MapPath(datafile));  
  35. //最后保存这个XML文档  
  36. navigator=null;  
  37. //释放类  
  38. xmldocument=null ;  
  39. //释放XML文档,这样其他程序可以用它 

C#编程实现显示XML文件结论

综上可知,C#编写XML应用程序不但快捷而且方便,在编写ASP.NET数据库应用程序时,用XML文件替代一些小的Table,能减少许多数据库存取连接,也能让其他网络程序更易使用这些数据。

目前XML的主要瓶颈在于文件系统的读出或写入,故应使用更多内存和缓存方式,如果信息量不是巨大无比且修改量也较小,而浏览量巨大的话,使用XML方法将是很好的选择;相反,如数据量巨大,应考虑使用支持XML的数据库,无论你使用ADO+连接其他数据库,还是使用SQL server,C#中都有直接的类函数可让这些数据库中的信息直接和XML交互访问。

【编辑推荐】

  1. C#与VB7比较详解
  2. C#连接Access浅析
  3. C#创建XML Web services学习经验
  4. C# Windows应用程序概述
  5. C# SmartPhone程序学习笔记
责任编辑:佚名 来源: 博客园
相关推荐

2009-09-09 18:00:55

C# XML编程

2009-09-09 18:20:29

C# XML编程

2009-08-18 17:05:08

C#操作xml文件

2009-08-24 17:58:19

C#读取XML文件

2009-08-21 10:00:43

C#创建XML文件XmlTextWrit

2009-08-12 16:26:30

C#读取XML文档

2009-08-25 09:19:01

C#实现窗体显示

2009-07-31 18:28:46

实现C#显示图像

2009-08-24 10:06:31

C#接口成员

2009-08-24 18:06:36

源程序代码C#读取XML文件

2009-08-12 11:33:23

C#实现文件下载

2009-09-03 09:44:02

DropDownLisC#递归

2009-09-08 15:12:07

C# ListBox

2009-08-18 16:42:49

C# 操作XML

2009-08-18 17:11:03

C#操作XML文件

2009-08-19 16:42:41

C#如何使用XML

2009-09-09 13:57:28

C# XML解析

2009-09-04 14:14:55

C#文档

2009-08-18 17:08:50

C#编写XML文档

2009-08-24 17:24:28

C#创建XML文档
点赞
收藏

51CTO技术栈公众号