使用DataSet读写xml

1. 了解DataSet加载xml文件形成的结构

2.读取,修改,删除xml节点实例

3. 一点说明及代码下载

<1>. 了解DataSet加载xml文件形成的结构

如果是对于下面的xml文件加载进ds的话,通过vs的调试窗口,得到加载形成的ds结构如下:

<? xml version="1.0" encoding="utf-8"  ?>
< bookstore >
   < book  genre ="fantasy"  ISBN ="2-3631-4" >
     < title > Oberon's Legacy </ title >
     < author > Corets, Eva </ author >
     < price > 5.95 </ price >
   </ book >
</ bookstore>

 

 通过上面的观察,可以看出ds在加载xml文件时,将节点的属性全部加载到DataRow中。

<2>. 读取,修改,删除xml节点实例

针对上面的xml文件的读取,修改操作就比较简单,仅仅是对ds的一些操作:关键代码如下:

            DataSet ds = new DataSet();   
            // 读取数据
            ds.ReadXml("./bookstore.xml");

            // 显示数据
            Console.WriteLine(ds.Tables[0].Rows[0]["title"]);

            // 需要首先循环读取,查找到数据,然后修改数据
            ds.Tables[0].Rows[0]["title"] = "change title";

            // 插入数据
            DataRow row = ds.Tables[0].NewRow();
            // 向row中添加数据
            row["genre"] = "genre";
            row["ISBN"] = "ISBN";
            row["title"] = "title";
            row["author"] = "author";
            row["price"] = "price";
            ds.Tables[0].Rows.Add(row);

            // 删除数据
            DataRow r = ds.Tables[0].Rows[0];
            ds.Tables[0].Rows.Remove(r);

            // 将修改完成的数据保存
            ds.WriteXml("./bookstore.xml");

            Console.ReadKey();

<3>. 一点说明及代码下载

由于上面的方法在每次读写时都需要重新生成一个xml文件(ds.WriteXml("./bookstore.xml");),即是将原先的文件覆盖,所以说上面的方法对于较小的文件有比较好的性能,同时能够减少使用System.Xml命名空间中程序出错。

/Files/xuqiang/csharp/XMLReader_Writer.zip

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值