爱易网
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 浏览次数:20542 次
第三章: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组件生成的方法
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
数据类型的转换<long->string->long>该如何解决
了解Developer Express控件包的前辈请进,该如何解决
一次性插入10万条数据,如何提高效率
<asp:CheckBox >勾选弹出确认取消的提示,两个有关问题求解答
原vs2005中DataList的DataKeys没e.Item.Item?
异步任务:使用任务简化异步编程
ASP.NET页面中冻结DataGrid的列或头部
【】ASP.NET中的一个小疑点!困惑n久了
^*对于未能加载视图状态
推荐阅读
更多>
关于URL编码的有关问题
变量怎么与实体类相关联起来
有没有办法预览影片,还有如何下载文件
来来来 输出图形解决办法
关于图片缓存解决方案
vs2010 连接服务器下的oracle数据库有关问题
System.Data.SqlClient.SqlConnection”未标记为可序列化?解决方法
DataGrid分页解决方法
获取web窗体上若干控件的属性值,大家教小弟我
用户控件发生 “Invalid postback or callback argument”异常,
.NET对IT专业人员的重要意义
DataGrid学习五_数据库应用
*100分,100分。为什么源代码一同打包了。在线30分钟内结贴。该如何解决
怎么实现这种排列效果
HOW TO:检索应用程序当前执行代码的引用信息
访问网页报错:Access is denied?待!
Asp.NET常用函数 (VB.net)
那个高手能帮小弟我把这段asp代码转换成.net
jquery判断登录解决方案
弹出新页传值的有关问题