C#對XML操作:寫入一筆XML記錄(2)
WEBASP.NET
當前位置:
開發者網絡
>>
技術教程
>>
.NET教程
>>
XML應用
>> 內容
精彩推薦
分類最新教程
分類熱點教程
C#對XML操作:寫入一筆XML記錄(2)
作者:
未知
日期:
2005-04-27
人氣:
投稿:
(
轉貼
)
來源:
未知
字體:
大
中
小
收藏:
加入瀏覽器收藏
以下正文:
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(); //綁定數據 myDs.Dispose(); } </script> <html> <head> <title>插入一條數據</title> </head> <body> <form runat="server"> <table width="100%"> <tr> <td>寫入前</td> <td>寫入後</td> </tr> <tr> <td valign="top"><asp:DataGrid id="PreData" runat="server"/></td> <td valign="top"><asp:DataGrid id="NextData" runat="server"/></td> </tr> </table> </form> </body> </html>
通過上面的操作,我們將得到的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>
大家可以比較跟上一篇添加數據時候的異同
相關文章: