XML与DataSet的相互转换类

送给大家一个XML与DataSet的相互转换的类:

XmlDatasetConvert 该类提供了四种方法:

    1、将xml对象内容字符串转换为DataSet
    2、将xml文件转换为DataSet
    3、将DataSet转换为xml对象字符串
    4、将DataSet转换为xml文件

XmlDatasetConvert.cs

 

 

 

using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Data;
using  System.IO;
using  System.Xml;

namespace  XmlDesign
ExpandedBlockStart.gifContractedBlock.gif
{
    
class XmlDatasetConvert
ExpandedSubBlockStart.gifContractedSubBlock.gif    
{
        
//将xml对象内容字符串转换为DataSet
        public static DataSet ConvertXMLToDataSet(string xmlData)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            StringReader stream 
= null;
            XmlTextReader reader 
= null;
            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                DataSet xmlDS 
= new DataSet();
                stream 
= new StringReader(xmlData);
                
//从stream装载到XmlTextReader
                reader = new XmlTextReader(stream);
                xmlDS.ReadXml(reader);
                
return xmlDS;
            }

            
catch (System.Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
throw ex;
            }

            
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
if (reader != null)
                    reader.Close();
            }

        }


        
//将xml文件转换为DataSet
        public static DataSet ConvertXMLFileToDataSet(string xmlFile)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            StringReader stream 
= null;
            XmlTextReader reader 
= null;
            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                XmlDocument xmld 
= new XmlDocument();
                xmld.Load(xmlFile);

                DataSet xmlDS 
= new DataSet();
                stream 
= new StringReader(xmld.InnerXml);
                
//从stream装载到XmlTextReader
                reader = new XmlTextReader(stream);
                xmlDS.ReadXml(reader);
                
//xmlDS.ReadXml(xmlFile);
                return xmlDS;
            }

            
catch (System.Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
throw ex;
            }

            
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
if (reader != null)
                    reader.Close();
            }

        }


        
//将DataSet转换为xml对象字符串
        public static string ConvertDataSetToXML(DataSet xmlDS)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            MemoryStream stream 
= null;
            XmlTextWriter writer 
= null;

            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                stream 
= new MemoryStream();
                
//从stream装载到XmlTextReader
                writer = new XmlTextWriter(stream, Encoding.Unicode);

                
//用WriteXml方法写入文件.
                xmlDS.WriteXml(writer);
                
int count = (int) stream.Length;
                
byte[] arr = new byte[count];
                stream.Seek(
0, SeekOrigin.Begin);
                stream.Read(arr, 
0, count);

                UnicodeEncoding utf 
= new UnicodeEncoding();
                
return utf.GetString(arr).Trim();
            }

            
catch (System.Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
throw ex;
            }

            
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
if (writer != null)
                    writer.Close();
            }

        }


        
//将DataSet转换为xml文件
        public static void ConvertDataSetToXMLFile(DataSet xmlDS, string xmlFile)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            MemoryStream stream 
= null;
            XmlTextWriter writer 
= null;

            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                stream 
= new MemoryStream();
                
//从stream装载到XmlTextReader
                writer = new XmlTextWriter(stream, Encoding.Unicode);

                
//用WriteXml方法写入文件.
                xmlDS.WriteXml(writer);
                
int count = (int) stream.Length;
                
byte[] arr = new byte[count];
                stream.Seek(
0, SeekOrigin.Begin);
                stream.Read(arr, 
0, count);

                
//返回Unicode编码的文本
                UnicodeEncoding utf = new UnicodeEncoding();
                StreamWriter sw 
= new StreamWriter(xmlFile);
                sw.WriteLine(
"<?xml version=\"1.0\" encoding=\"utf-8\"?>");
                sw.WriteLine(utf.GetString(arr).Trim());
                sw.Close();
            }

            
catch (System.Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
throw ex;
            }

            
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
if (writer != null)
                    writer.Close();
            }

        }

    }

}



使用实例

using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Xml;
using  System.Data;

namespace  XmlDesign
ExpandedBlockStart.gifContractedBlock.gif
{
    
class Program
ExpandedSubBlockStart.gifContractedSubBlock.gif    
{
        
static void Main(string[] args)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            DataSet ds 
= new DataSet();
ContractedSubBlock.gifExpandedSubBlockStart.gif            
转换一个XML文件(本地\网络均可)为一个DataSet#region 转换一个XML文件(本地\网络均可)为一个DataSet
            
//http://news.baidu.com/n?cmd=1&class=sportnews&tn=rss
            
//F:\study\001CSharp_Study\002Source\XmlDesign\XmlDesign\Save_Plan.xml
            ds = XmlDatasetConvert.ConvertXMLFileToDataSet(@"http://news.baidu.com/n?cmd=1&class=sportnews&tn=rss");
ExpandedSubBlockStart.gifContractedSubBlock.gif            Console.WriteLine(
"数据集名为\"{0}\",包含{1}个表", ds.DataSetName, ds.Tables.Count);
            
foreach (DataTable dt in ds.Tables)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                PrintTableName(dt.TableName);
            }

            
#endregion


ContractedSubBlock.gifExpandedSubBlockStart.gif            
构造一个DataSet,并转换为XML字符串#region 构造一个DataSet,并转换为XML字符串
            DataSet ds1 
= new DataSet();
            DataTable dt1 
= new DataTable();
            dt1.TableName 
= "test";
            dt1.Columns.Add(
"id");
            dt1.Columns.Add(
"name");
            dt1.Rows.Add(
"i001""hekui");
            dt1.Rows.Add(
"i002""liyang");

            DataTable dt2 
= new DataTable();
            dt2.TableName 
= "test1";
            dt2.Columns.Add(
"bookid");
            dt2.Columns.Add(
"bookname");
            dt2.Rows.Add(
"b001""书本1");
            dt2.Rows.Add(
"b002""书本2");

            ds1.Tables.Add(dt1);
            ds1.Tables.Add(dt2);
            ds1.DataSetName 
= "方案";
            
string xmlOut = XmlDatasetConvert.ConvertDataSetToXML(ds1);
            
#endregion


ContractedSubBlock.gifExpandedSubBlockStart.gif            
转换一个XML字符串为一个DataSet#region 转换一个XML字符串为一个DataSet
            DataSet ds2 
= new DataSet();
            ds2 
= XmlDatasetConvert.ConvertXMLToDataSet(xmlOut);
ExpandedSubBlockStart.gifContractedSubBlock.gif            Console.WriteLine(
"数据集名为\"{0}\",包含{1}个表", ds2.DataSetName, ds2.Tables.Count);
            
foreach (DataTable dt in ds2.Tables)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                PrintTableName(dt.TableName);
            }

            
#endregion


ContractedSubBlock.gifExpandedSubBlockStart.gif            
转换一个Dataset为一个XML文件#region 转换一个Dataset为一个XML文件
            XmlDatasetConvert.ConvertDataSetToXMLFile(ds2, 
"c:\\adadsda1.xml");
            
#endregion


            Console.ReadLine();
        }


        
private static void PrintTableName(string tableName)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            Console.WriteLine(tableName);
        }

    }

}







转载于:https://www.cnblogs.com/xocom/archive/2008/07/29/XML.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值