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

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

3. 一点说明及代码下载

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

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

<?xmlversion="1.0"encoding="utf-8"?>
<bookstore>
<bookgenre="fantasy"ISBN="2-3631-4">
<title>Oberon'sLegacy</title>
<author>Corets,Eva</author>
<price>5.95</price>
</book>
</bookstore>

使用DataSet读写xml

通过上面的观察,可以看出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

相关文章: