下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

编程入门教程之C#操作XML文档的基础教程

作者:Comet     来源: 课课家 www.kokojia.com点击数:2116发布时间: 2015-06-11 14:22:34

标签: 编程语言编程教程编程入门教程

大神带你学编程,欢迎选课

Extensible Markup Language, XML(可扩展标记编程语言),将其与结构化的电子文件标记语言,它可被用来标记的数据标记,定义数据的类型,是一种技术,它允许用户定义他们自己的标记语言的源语言。 XML是标准通用标记语言(SGML)的子集是理想的网络传输。 XML提供了一个统一的方法来描述和交换独立于应用程序或结构化数据供应商。点击这里,看看有什么是XMLC#提供了许多相关的类XML数据处理,如一流的加工流: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加入以下代码:




代码中划线部分的作用是当按了“选择”按钮后,执行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文件,而不是一些小表,可以减少数据库访问连接的数量,同时也使程序更易于使用这些网络的数据。
主要瓶颈XML被读取或写入到文件系统,它应该使用更多的内存和缓存模式,如果没有信息的巨大数量和修改量小,但伟大的意见,使用XML的方法是非常不错的选择;相反,这样一个庞大的数据量,你应该考虑使用XML数据库的支持,无论您使用ADO+连接到其他数据库,或使用SQL Server,C#中直接类函数直接和XML允许这些数据库中的信息交互式访问。推荐猜你喜欢的编程培训课程:c#视频教程-【零基础学通C语言系列教程】

赞(28)
踩(2)
分享到:
华为认证网络工程师 HCIE直播课视频教程