爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
ASP.NET教程
C#对XML操作:编辑XML文件内容
C#对XML操作:编辑XML文件内容
日期:2013-05-28 浏览次数:20665 次
第三章:XML文件记录的编辑
使用C#来编辑XML文件,最方便的方法当然还是使用DATASET
我们继续使用上一篇中的XML文件,如下:
<users> <xs:schema id="users" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> <xs:element name="users" msdata:IsDataSet="true" msdata:Locale="zh-CN"> <xs:complexType> <xs:choice maxOccurs="unbounded"> <xs:element name="user"> <xs:complexType> <xs:sequence> <xs:element name="userName" type="xs:string" minOccurs="0" msdata:Ordinal="0" /> <xs:element name="userPass" type="xs:string" minOccurs="0" msdata:Ordinal="1" /> </xs:sequence> <xs:attribute name="id" type="xs:string" /> </xs:complexType> </xs:element> </xs:choice> </xs:complexType> </xs:element> </xs:schema> <user id="1"> <userName>outrace</userName> <userPass>mypass</userPass> </user> <user id="2"> <userName>trace</userName> <userPass>mypass</userPass> </user> <user id="3"> <userName>new user</userName> <userPass>new passwd</userPass> </user></users>
则,我们新建一个XML文件,内容如下:
<% @ Import Namespace="System.IO" %><% @ Import Namespace="System.Xml" %><% @ Import Namespace="System.Data" %><Script Language="C#" Runat="Server">public void Page_Load(Object src,EventArgs e){ /** 版 权 : copyright by SEM IT DEPARTMENT* 版 本 : version 0.0.1* 文 件 : EditXml.aspx* 用 途 : 编辑XML文件(修改、删除行)* 作 者 : 欧阳云天 @2005-4-9* 邮 箱 : outrace@soueast-motor.com* 修 改 :*/ String fileName;fileName = "users_2.xml";DataSet myDs = new DataSet();try{FileStream fin ;fin = new FileStream(Server.MapPath("./files/"+fileName), FileMode.Open, FileAccess.Read, FileShare.ReadWrite);myDs.ReadXml(fin);fin.Close();}catch (Exception ex){ Response.Write(ex.Message);}//绑定修改前的XMLOldData.DataSource = myDs.Tables[0].DefaultView;OldData.DataBind(); //当DS当中增加新行DataRow newRow = myDs.Tables[0].NewRow();newRow["id"] = "44";newRow["userName"] = "test user";newRow["userPass"] = "test passwd";myDs.Tables[0].Rows.Add(newRow); //绑定新增一条记录的数据NewData.DataSource = myDs.Tables[0].DefaultView;NewData.DataBind(); //进行过滤 DataRow[] editRow = myDs.Tables[0].Select("id = '44'"); for(int i=0;i<editRow.Length;i++){ editRow[i]["userName"] = "changed user"; editRow[i]["userPass"] = "changed passwd";} //绑定修改记录后的数据EditData.DataSource = myDs.Tables[0].DefaultView;EditData.DataBind(); for(int i=0;i<editRow.Length;i++){ editRow[i].Delete(); //把该数据删除} //绑定删除记录后的数据DeleData.DataSource = myDs.Tables[0].DefaultView;DeleData.DataBind(); //将myDs的改变写入XMLtry{myDs.WriteXml(Server.MapPath("./files/"+fileName), XmlWriteMode.WriteSchema);}catch (Exception ex){ Response.Write(ex.Message);}myDs.Dispose();}</script><html><head> <title>编辑数据</title></head><body> <form runat="server"> <table width="100%"> <tr> <td>原数据</td> <td>新增行</td> <td>修改行</td> <td>删除行</td> </tr> <tr> <td valign="top"><asp:DataGrid id="OldData" runat="server"/></td> <td valign="top"><asp:DataGrid id="NewData" runat="server"/></td> <td valign="top"><asp:DataGrid id="EditData" runat="server"/></td> <td valign="top"><asp:DataGrid id="DeleData" runat="server"/></td> </tr> </table> </form></body></html>
大家运行完这个文件,就可以非常直观的看到操作效果,由于我们是最后才保存,所以XML文件的内容没有发生改变
上一篇:[环境搭建] VS-Visual Studio-IIS Express 支持局域网访问 远程调试
下一篇:用C#生成Excel文件的方法和Excel.dll组件生成的方法
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
aspx网站项目如果新建一个类时,只能存放在App_Code文件夹中吗?该怎么处理
怎样在Web自定义控件的属性中使用js代码解决方法
进来看看,奇怪的有关问题
?web程序能否访问注册表,如何解决
使用menu控件时为什么老是报这样的异常?
急一个MM问小弟我的题,小弟我想不出来,大家来帮帮忙
SQL 小弟我想获得列之间时间差的平均值
两个关于赋值的有关问题
求诸位前辈详细解释下
推荐阅读
更多>
急待!asp.net上传文件自动解压缩
有能控制下载进度的方法吗?该如何解决
请教除了OnItemDataBound外还有什么好的办法可以实现以下功能呢
还是table增加行的有关问题
求重启sql05的命令解决办法
求jquery神来指点小弟。
只有这么多份 两个有关问题一起问
使用AOP微型框架的例子
接收资料保存,不弹出保存文件的对话框
关于asp.net 导入Excel 到数据库的方法解决思路
小弟我买的华硕笔记本用来开发,想装windows 2008 Server,但大多数没有2008下面的驱动。请教买什么笔记本有2008 64位驱动好
关于datagirdview 导出excel乱码有关问题
能不能在window xp下安装SQL SERVER和Vs 2005,进行开发呢?解决方法
vs2008设启动项目有关问题?高分
在.net顶用什么方法取出与正则表达式匹配的字符呢
高难度的SQL 语句 ,高手请入(因为急所以二发啦,斑竹手下留情)解决方案
为啥这段代码的的checkbox没有设置为autopostback=true却可以改变checkbox.checked属性
跪求sql获取最后一条记录,该怎么处理
小弟我用GridView 对某一项进行编辑时,数据库不能获取编辑后的值,是咋回事,哪位高手能帮帮小弟我呢
小弟我想用一DataList显示学生姓名(sName),在模板列用LinkButton与sName绑定,DataKeyField为学号(sNo),当小弟我点LinkButton时,在GridView中