C#操作XML初步(5) | 第二章:往现有XML文件添加记录 另外C#又提供了一个更方便的方式让我们操作XML,那就是DATASET 其实我们可以这样认为,DATASET其实就是多个XML文件,通过DATASET一些内置的方法和属性操作XML,非常灵活 我们继续假设,现有一个XML文件,如 |
<?xml version="1.0" encoding="gb2312"?> <users> <user id="1"> <userName>outrace</userName> <userPass>mypass</userPass> </user> <user id="2"> <userName>trace</userName> <userPass>mypass</userPass> </user> </users> 则通过下面的代码进行写入操做 <% @ Import Namespace="System.IO" %> <% @ Import Namespace="System.Xml" %> <% @ Import Namespace="System.Data" %> <Script Language="C#" Runat="Server" Debug="true"> public void Page_Load(Object src,EventArgs e) { /* * 版 权 : copyright by SEM IT DEPARTMENT * 版 本 : version 0.0.1 * 文 件 : InsertXml_2.aspx * 用 途 : 使用DATASET的方式往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); } //绑定修改前的XML PreData.DataSource = myDs.Tables[0].DefaultView; //指定数据源 PreData.DataBind(); //绑定数据 //当DS当中增加新行 //在这里我们可以看到,其实原XML数据里面的属性,我们一样可以直接使用DataRow[]数组来得到,而不仅仅是节点 DataRow newRow = myDs.Tables[0].NewRow(); newRow["id"] = "3"; newRow["userName"] = "new user"; newRow["userPass"] = "new passwd"; myDs.Tables[0].Rows.Add(newRow); //将myDs的改变写入XML try { FileStream dataOut; dataOut = new FileStream(Server.MapPath("./files/"+fileName), FileMode.Open, FileAccess.Write, FileShare.ReadWrite); myDs.WriteXml(dataOut, XmlWriteMode.WriteSchema); dataOut.Close(); } catch (Exception ex) { Response.Write(ex.Message); } //绑定修改后的XML NextData.DataSource = myDs.Tables[0].DefaultView; //指定数据源 NextData.DataBind(); //绑定数据 |