c#解析XML到DATASET及dataset转为xml文件函数

//将xml对象内容字符串转换为DataSet

public static DataSet ConvertXMLToDataSet(string xmlData)

{

StringReader stream = null;

XmlTextReader reader = null;

try

{

DataSet xmlDS = new DataSet();

stream = new StringReader(xmlData);

//从stream装载到XmlTextReader

reader = new XmlTextReader(stream);

xmlDS.ReadXml(reader);

return xmlDS;

}

catch (System.Exception ex)

{

throw ex;

}

finally

{

if (reader != null)

reader.Close();

}

}

//将xml文件转换为DataSet

public static DataSet ConvertXMLFileToDataSet(string xmlFile)

{

StringReader stream = null;

XmlTextReader reader = null;

try

{

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)

{

throw ex;

}

finally

{

if (reader != null)

reader.Close();

}

}

//将DataSet转换为xml对象字符串

public static string ConvertDataSetToXML(DataSet xmlDS)

{

MemoryStream stream = null;

XmlTextWriter writer = null;

try

{

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)

{

throw ex;

}

finally

{

if (writer != null)

writer.Close();

}

}

//将DataSet转换为xml文件

public static void ConvertDataSetToXMLFile(DataSet xmlDS, string xmlFile)

{

MemoryStream stream = null;

XmlTextWriter writer = null;

try

{

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)

{

throw ex;

}

finally

{

if (writer != null)

writer.Close();

}

}

时间: 2024-08-09 15:09:46

c#解析XML到DATASET及dataset转为xml文件函数的相关文章

DataSet - DataTable - DataRow 读取 xml 文件 + 搜索

DataSet ds = XmlHelper.GetDataSetByXml(AppDomain.CurrentDomain.BaseDirectory + "/Config/ConfigName.xml");//取得xml文件 DataTable dt = ds.Tables["table_Name"];//取得xml文件的节点内容 DataRow[] dr = dr = ds.Tables["table_Name"].Select("

DataSet与二进制文件和XML文件

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86

XML系列:(5)XML解析-JAXP的DOM解析方式修改XML

DOM.SAX和StAX只是解析方式,没有API. JAXP是SUN提供的一套XML解析API.JAXP(Java API for XMLProcessing,意为XML处理的Java API) JAXP很好的支持DOM和SAX解析. JAXP开发包是JAVASE的一部分,它由java.xml.org.w3c.dom.org.xml.sax包及其子包组成 1.以DOM解析方式修改XML 1.1.将Document树保存到文件中 package com.rk.xml.e_jaxp_dom_writ

使用Dom4j解析包含有DB连接信息的XML文件以及节点属性的获取

包含DB连接信息的XML文件 1 <!--示例1——三级显示--> 2 <db-connections> 3 <connection> 4 <name>DBTest</name> 5 <jndi></jndi> 6 <url> 7 <![CDATA[jdbc:mysql://localhost:3306/db_test?useUnicode=true&characterEncoding=UTF8]

BIP_Case_将原有Report Builer报表全部转为XML Publisher形式

一.案例分析 Oracle Report Builder  因落伍的技术和糟糕的交互性,特别是无法随心所欲的进行排版,逐渐被淘汰,而BI(XML) Publisher  也是其中的一种替代技术, 此文介绍了如何将Report Builder建立的RDF文件转换成最新的XML Publisher所使用的xml data definition 和 rtf template definition,从而实现数据源和输出模板分离,从而将原有难易维护的report builder 替代为易维护的XML Pu

sqlserver中将行数据转为Xml文件格式

将sqlserver中的某张表中的行数据转为XML格式的文件的方法: 语法:select * from  表名   for xml path(xml文件中父节点的名称) 案例: //  在Movie数据库下创建一张用户基本信息表[UserInfoes]: USE [Movie]GOCREATE TABLE [dbo].[UserInfoes]( [userId] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY, [userName] [varchar](50)

web.xml加载顺序与web.xml常用节点解析

web.xml加载顺序 应用服务器启动时web.xml加载过程,至于这些节点在xml文件中的前后顺序没有关系,不过有些应用服务器,我曾碰到过的 websphere就严格要求web.xml的节点顺序,否则部署不成功,所以还是赞成按照web.xml标准格式写 总的来说, web.xml 的加载顺序是:context-param --> listener --> filter --> servlet 其中, 如果 web.xml 中出现了相同的节点, 则是按照在配置文件中出现的先后顺序来加载的

XML系列:(7)XML解析-Dom4j的DOM解析方式更新XML

Dom4j工具,是非官方的,不在jdk中. 使用步骤: 1)导入dom4j的核心包. dom4j-1.6.1.jar 2)编写Dom4j读取xml文件的代码 1.更新XML 1.1.写出内容到xml文档 package com.rk.xml.g_dom4j_write; import java.io.File; import java.io.FileOutputStream; import org.dom4j.Document; import org.dom4j.io.SAXReader; im

JAVA基础学习之XMLCDATA区、XML处理指令、XML约束概述、JavaBean、XML解析(8)

1.CDATA区在编写XML文件时,有些内容可能不想让解析引擎解析执行,而是当作原始内容处理.遇到此种情况,可以把这些内容放在CDATA区里,对于CDATA区域内的内容,XML解析程序不会处理,而是直接原封不动的输出.语法:<![CDATA[ 内容 ]]> <![CDATA[ <book> <br/> </book> ]]> 2.处理指令处理指令,简称PI (processing instruction).处理指令用来指挥解析引擎如何解析XML文

XML系列:(3)XML解析

xml文件除了给开发者看,更多的情况使用程序读取xml文件的内容,这叫做xml解析. 1.XML解析方式和工具 1.1.XML解析方式 XML解析分为两种方式:DOM和SAX. DOM:W3C组织推荐的一种解析方式.xml解析器一次性把整个xml文档加载进内存,然后在内存中构建一颗Document的对象树,通过Document对象,得到树上的节点对象,通过节点对象访问(操作)到xml文档的内容.缺点: 不适合读取大容量的xml文件,容易导致内存溢出. SAX:(Simple API for XM