C#操作XML简要教程

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

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

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

  C#提供了许多相关类处理Xml数据,如处理stream的类: XmlReaderXmlWriter DOM的类:XmlNodeXmlDocumentXmlElement; Xpath的类:XmlNavigatorXSLT的类:XslTransform

 

 

  显示Xml文件内容

  用C#编程实现显示Xml文件中信息的方法是使用.Net提供的标准类把Xml文件内容读入一个StreamReader类对象中,再用XmlDataDocument类的DataSetXml的方法去读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 FormDataGrid的功能,我们需要增加下面的函数:

  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下插入另一些元素如CountryE-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 serverC#中都有直接的类函数可让这些数据库中的信息直接和Xml交互访问。

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值