xml 与 DataSet 互相转换

本文转载:http://www.cnblogs.com/30ErLi/archive/2010/09/21/1832694.html

 

XmlDatasetConvert 该类提供了四种方法:

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

 

xml 与 DataSet 互相转换using System;
xml 与 DataSet 互相转换
using System.Collections.Generic;
xml 与 DataSet 互相转换
using System.Text;
xml 与 DataSet 互相转换
using System.Data;
xml 与 DataSet 互相转换
using System.IO;
xml 与 DataSet 互相转换
using System.Xml;
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换
namespace XmlDesign
xml 与 DataSet 互相转换xml 与 DataSet 互相转换
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换    
class XmlDatasetConvert
xml 与 DataSet 互相转换xml 与 DataSet 互相转换    
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换        
//将xml对象内容字符串转换为DataSet
xml 与 DataSet 互相转换
        public static DataSet ConvertXMLToDataSet(string xmlData)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换        
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换            StringReader stream 
= null;
xml 与 DataSet 互相转换            XmlTextReader reader 
= null;
xml 与 DataSet 互相转换            
try
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                DataSet xmlDS 
= new DataSet();
xml 与 DataSet 互相转换                stream 
= new StringReader(xmlData);
xml 与 DataSet 互相转换                
//从stream装载到XmlTextReader
xml 与 DataSet 互相转换
                reader = new XmlTextReader(stream);
xml 与 DataSet 互相转换                xmlDS.ReadXml(reader);
xml 与 DataSet 互相转换                
return xmlDS;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
catch (System.Exception ex)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
throw ex;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
finally
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
if (reader != null)
xml 与 DataSet 互相转换                    reader.Close();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换        
//将xml文件转换为DataSet
xml 与 DataSet 互相转换
        public static DataSet ConvertXMLFileToDataSet(string xmlFile)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换        
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换            StringReader stream 
= null;
xml 与 DataSet 互相转换            XmlTextReader reader 
= null;
xml 与 DataSet 互相转换            
try
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                XmlDocument xmld 
= new XmlDocument();
xml 与 DataSet 互相转换                xmld.Load(xmlFile);
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换                DataSet xmlDS 
= new DataSet();
xml 与 DataSet 互相转换                stream 
= new StringReader(xmld.InnerXml);
xml 与 DataSet 互相转换                
//从stream装载到XmlTextReader
xml 与 DataSet 互相转换
                reader = new XmlTextReader(stream);
xml 与 DataSet 互相转换                xmlDS.ReadXml(reader);
xml 与 DataSet 互相转换                
//xmlDS.ReadXml(xmlFile);
xml 与 DataSet 互相转换
                return xmlDS;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
catch (System.Exception ex)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
throw ex;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
finally
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
if (reader != null)
xml 与 DataSet 互相转换                    reader.Close();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换        
//将DataSet转换为xml对象字符串
xml 与 DataSet 互相转换
        public static string ConvertDataSetToXML(DataSet xmlDS)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换        
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换            MemoryStream stream 
= null;
xml 与 DataSet 互相转换            XmlTextWriter writer 
= null;
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换            
try
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                stream 
= new MemoryStream();
xml 与 DataSet 互相转换                
//从stream装载到XmlTextReader
xml 与 DataSet 互相转换
                writer = new XmlTextWriter(stream, Encoding.Unicode);
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换                
//用WriteXml方法写入文件.
xml 与 DataSet 互相转换
                xmlDS.WriteXml(writer);
xml 与 DataSet 互相转换                
int count = (int) stream.Length;
xml 与 DataSet 互相转换                
byte[] arr = new byte[count];
xml 与 DataSet 互相转换                stream.Seek(
0, SeekOrigin.Begin);
xml 与 DataSet 互相转换                stream.Read(arr, 
0, count);
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换                UnicodeEncoding utf 
= new UnicodeEncoding();
xml 与 DataSet 互相转换                
return utf.GetString(arr).Trim();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
catch (System.Exception ex)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
throw ex;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
finally
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
if (writer != null)
xml 与 DataSet 互相转换                    writer.Close();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换        
//将DataSet转换为xml文件
xml 与 DataSet 互相转换
        public static void ConvertDataSetToXMLFile(DataSet xmlDS, string xmlFile)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换        
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换            MemoryStream stream 
= null;
xml 与 DataSet 互相转换            XmlTextWriter writer 
= null;
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换            
try
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                stream 
= new MemoryStream();
xml 与 DataSet 互相转换                
//从stream装载到XmlTextReader
xml 与 DataSet 互相转换
                writer = new XmlTextWriter(stream, Encoding.Unicode);
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换                
//用WriteXml方法写入文件.
xml 与 DataSet 互相转换
                xmlDS.WriteXml(writer);
xml 与 DataSet 互相转换                
int count = (int) stream.Length;
xml 与 DataSet 互相转换                
byte[] arr = new byte[count];
xml 与 DataSet 互相转换                stream.Seek(
0, SeekOrigin.Begin);
xml 与 DataSet 互相转换                stream.Read(arr, 
0, count);
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换                
//返回Unicode编码的文本
xml 与 DataSet 互相转换
                UnicodeEncoding utf = new UnicodeEncoding();
xml 与 DataSet 互相转换                StreamWriter sw 
= new StreamWriter(xmlFile);
xml 与 DataSet 互相转换                sw.WriteLine(
"<?xml version=\"1.0\" encoding=\"utf-8\"?>");
xml 与 DataSet 互相转换                sw.WriteLine(utf.GetString(arr).Trim());
xml 与 DataSet 互相转换                sw.Close();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
catch (System.Exception ex)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
throw ex;
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换            
finally
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换                
if (writer != null)
xml 与 DataSet 互相转换                    writer.Close();
xml 与 DataSet 互相转换            }

xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换    }

xml 与 DataSet 互相转换}

 


使用

 

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

xml 与 DataSet 互相转换            
#endregion

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
构造一个DataSet,并转换为XML字符串#region 构造一个DataSet,并转换为XML字符串
xml 与 DataSet 互相转换            DataSet ds1 
= new DataSet();
xml 与 DataSet 互相转换            DataTable dt1 
= new DataTable();
xml 与 DataSet 互相转换            dt1.TableName 
= "test";
xml 与 DataSet 互相转换            dt1.Columns.Add(
"id");
xml 与 DataSet 互相转换            dt1.Columns.Add(
"name");
xml 与 DataSet 互相转换            dt1.Rows.Add(
"i001""hekui");
xml 与 DataSet 互相转换            dt1.Rows.Add(
"i002""liyang");
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换            DataTable dt2 
= new DataTable();
xml 与 DataSet 互相转换            dt2.TableName 
= "test1";
xml 与 DataSet 互相转换            dt2.Columns.Add(
"bookid");
xml 与 DataSet 互相转换            dt2.Columns.Add(
"bookname");
xml 与 DataSet 互相转换            dt2.Rows.Add(
"b001""书本1");
xml 与 DataSet 互相转换            dt2.Rows.Add(
"b002""书本2");
xml 与 DataSet 互相转换
xml 与 DataSet 互相转换            ds1.Tables.Add(dt1);
xml 与 DataSet 互相转换            ds1.Tables.Add(dt2);
xml 与 DataSet 互相转换            ds1.DataSetName 
= "方案";
xml 与 DataSet 互相转换            
string xmlOut = XmlDatasetConvert.ConvertDataSetToXML(ds1);
xml 与 DataSet 互相转换            
#endregion

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

xml 与 DataSet 互相转换            
#endregion

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换xml 与 DataSet 互相转换            
转换一个Dataset为一个XML文件#region 转换一个Dataset为一个XML文件
xml 与 DataSet 互相转换            XmlDatasetConvert.ConvertDataSetToXMLFile(ds2, 
"c:\\adadsda1.xml");
xml 与 DataSet 互相转换            
#endregion

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换            Console.ReadLine();
xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换
xml 与 DataSet 互相转换        
private static void PrintTableName(string tableName)
xml 与 DataSet 互相转换xml 与 DataSet 互相转换        
xml 与 DataSet 互相转换{
xml 与 DataSet 互相转换            Console.WriteLine(tableName);
xml 与 DataSet 互相转换        }

xml 与 DataSet 互相转换    }

xml 与 DataSet 互相转换}

 

上一篇:[ 搭建Redis本地服务器实践系列二 ] :图解CentOS7配置Redis


下一篇:centos7安装图形界面