C#对XML操作:使用DATASET编辑XML文件内容

C#操作XML初步(5)
第三章: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>

.aspx

<% @ 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);
 }

 //绑定修改前的XML
 OldData.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的改变写入XML
 try
 {
  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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值