打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
一个通过DataSet操作XML的类(源代码)
一个通过DataSet操作XML的类(源代码) 


复制代码 代码如下:
using System; 
using System.Data; 
using System.Xml; 
using System.Windows.Forms; 

//*************************************** 
// 作者: ∮明天去要饭 
// QICQ: 305725744 
// .Net群: 6370988 
// http://blog.csdn.net/kgdiwss 
//*************************************** 

namespace YSTRP.Common 
/// 
/// OperateXmlByDataSet 的摘要说明。 
/// 
public class OperateXmlByDataSet 
public OperateXmlByDataSet() 
// 
// TODO: 在此处添加构造函数逻辑 
// 

#region GetDataSetByXml 
/// 
/// 读取xml直接返回DataSet 
/// 
/// xml文件相对路径 
/// 
public static DataSet GetDataSetByXml(string strXmlPath) 
try 
DataSet ds = new DataSet(); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 
if(ds.Tables.Count > 0) 
return ds; 
return null; 
catch(Exception ex) 
System.Windows.Forms.MessageBox.Show(ex.ToString()); 
return null; 
#endregion 
#region GetDataViewByXml 
/// 
/// 读取Xml返回一个经排序或筛选后的DataView 
/// 
/// 
/// 筛选条件,如:"name = 'kgdiwss'" 
/// 排序条件,如:"Id desc" 
/// 
public static DataView GetDataViewByXml(string strXmlPath,string strWhere,string strSort) 
try 
DataSet ds = new DataSet(); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 
DataView dv = new DataView(ds.Tables[0]); 
if(strSort != null) 
dv.Sort = strSort; 
if(strWhere != null) 
dv.RowFilter = strWhere; 
return dv; 
catch(Exception) 
return null; 
#endregion 


#region WriteXmlByDataSet 
/// 
/// 向Xml文件插入一行数据 
/// 
/// xml文件相对路径 
/// 要插入行的列名数组,如:string[] Columns = {"name","IsMarried"}; 
/// 要插入行每列的值数组,如:string[] ColumnValue={"明天去要饭","false"}; 
/// 成功返回true,否则返回false 
public static bool WriteXmlByDataSet(string strXmlPath,string[] Columns,string[] ColumnValue) 
try 
//根据传入的XML路径得到.XSD的路径,两个文件放在同一个目录下 
string strXsdPath = strXmlPath.Substring(0,strXmlPath.IndexOf(".")) + ".xsd"; 

DataSet ds = new DataSet(); 
//读xml架构,关系到列的数据类型 
ds.ReadXmlSchema(GetXmlFullPath(strXsdPath)); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 
DataTable dt = ds.Tables[0]; 
//在原来的表格基础上创建新行 
DataRow newRow = dt.NewRow(); 

//循环给一行中的各个列赋值 
for(int i=0; i< Columns.Length; i++) 
newRow[Columns[i]] = ColumnValue[i]; 
dt.Rows.Add(newRow); 
dt.AcceptChanges(); 
ds.AcceptChanges(); 

ds.WriteXml(GetXmlFullPath(strXmlPath)); 
return true; 
catch(Exception) 
return false; 
#endregion 


#region UpdateXmlRow 
/// 
/// 更行符合条件的一条Xml记录 
/// 
/// XML文件路径 
/// 列名数组 
/// 列值数组 
/// 条件列名 
/// 条件列值 
/// 
public static bool UpdateXmlRow(string strXmlPath,string[] Columns,string[] ColumnValue,string strWhereColumnName,string strWhereColumnValue) 
try 
string strXsdPath = strXmlPath.Substring(0,strXmlPath.IndexOf(".")) + ".xsd"; 

DataSet ds = new DataSet(); 
//读xml架构,关系到列的数据类型 
ds.ReadXmlSchema(GetXmlFullPath(strXsdPath)); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 

//先判断行数 
if(ds.Tables[0].Rows.Count > 0) 
for(int i=0; i< ds.Tables[0].Rows.Count; i++) 
//如果当前记录为符合Where条件的记录 
if(ds.Tables[0].Rows[i][strWhereColumnName].ToString().Trim().Equals(strWhereColumnValue)) 
//循环给找到行的各列赋新值 
for(int j=0; j < Columns.Length; j++) 
ds.Tables[0].Rows[i][Columns[j]] = ColumnValue[j]; 
//更新DataSet 
ds.AcceptChanges(); 
//重新写入XML文件 
ds.WriteXml(GetXmlFullPath(strXmlPath)); 
return true; 

return false; 
catch(Exception) 
return false; 
#endregion 


#region DeleteXmlRowByIndex 
/// 
/// 通过删除DataSet中iDeleteRow这一行,然后重写Xml以实现删除指定行 
/// 
/// 
/// 要删除的行在DataSet中的Index值 
public static bool DeleteXmlRowByIndex(string strXmlPath,int iDeleteRow) 
try 
DataSet ds = new DataSet(); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 
if(ds.Tables[0].Rows.Count > 0) 
//删除符号条件的行 
ds.Tables[0].Rows[iDeleteRow].Delete(); 
ds.WriteXml(GetXmlFullPath(strXmlPath)); 
return true; 
catch(Exception) 
return false; 
#endregion 


#region DeleteXmlRows 
/// 
/// 删除strColumn列中值为ColumnValue的行 
/// 
/// xml相对路径 
/// 列名 
/// strColumn列中值为ColumnValue的行均会被删除 
/// 
public static bool DeleteXmlRows(string strXmlPath,string strColumn,string[] ColumnValue) 
try 
DataSet ds = new DataSet(); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 

//先判断行数 
if(ds.Tables[0].Rows.Count > 0) 
//判断行多还是删除的值多,多的for循环放在里面 
if(ColumnValue.Length > ds.Tables[0].Rows.Count) 
for(int i=0; i < ds.Tables[0].Rows.Count; i++) 
for(int j=0; j < ColumnValue.Length; j++) 
if(ds.Tables[0].Rows[i][strColumn].ToString().Trim().Equals(ColumnValue[j])) 
ds.Tables[0].Rows[i].Delete(); 
else 
for(int j=0; j < ColumnValue.Length; j++) 
for(int i=0; i < ds.Tables[0].Rows.Count; i++) 
if(ds.Tables[0].Rows[i][strColumn].ToString().Trim().Equals(ColumnValue[j])) 
ds.Tables[0].Rows[i].Delete(); 
ds.WriteXml(GetXmlFullPath(strXmlPath)); 
return true; 
catch(Exception) 
return false; 
#endregion 


#region DeleteXmlAllRows 
/// 
/// 删除所有行 
/// 
/// XML路径 
/// 
public static bool DeleteXmlAllRows(string strXmlPath) 
try 
DataSet ds = new DataSet(); 
ds.ReadXml(GetXmlFullPath(strXmlPath)); 
//如果记录条数大于0 
if(ds.Tables[0].Rows.Count > 0) 
//移除所有记录 
ds.Tables[0].Rows.Clear(); 
//重新写入,这时XML文件中就只剩根节点了 
ds.WriteXml(GetXmlFullPath(strXmlPath)); 
return true; 
catch(Exception) 
return false; 
#endregion 


#region GetXmlFullPath 
/// 
/// 返回完整路径 
/// 
/// Xml的路径 
/// 
public static string GetXmlFullPath(string strPath) 
if(strPath.IndexOf(":") > 0) 
return strPath; 
else 
return Application.StartupPath + strPath; 
#endregion 

详细出处参考:http://www.jb51.net/article/18576.htm
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
通过DataSet操作XML
将Xml字符串转换成(DataTable || DataSet)对象 !同样取反转换XML
XML与DataTable/DataSet互转(C#) 把数据库中表的内容转存为XML文件
用xml文件保存系统设置
C#获取Excel里sheet名,其表内容
DataSet批量更新数据库
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服