使用DataSet读写xml
1. 了解DataSet加载xml文件形成的结构
2.读取,修改,删除xml节点实例
3. 一点说明及代码下载
<1>. 了解DataSet加载xml文件形成的结构
如果是对于下面的xml文件加载进ds的话,通过vs的调试窗口,得到加载形成的ds结构如下:
< 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文件时,将节点的属性(例如genre)全部加载到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();
上面代码能够解决xml原先存在节点的情况,如果原先xml文件中没有节点,只能手动添加,需要手动编写代码,下面是一个简单示例:
ds.ReadXml(xmlPath);
生成如下格式的xml文件:
< bcaster >
< item item_url ="HomePageBanners/4e504e3e-a30b-47da-acfd-2a07237dc9e2.jpg" link ="./ViewPictureNews.aspx?id=4e504e3e-a30b-47da-acfd-2a07237dc9e2" itemtitle ="" />
</bcaster>