在工作中有个小任务,要把某个格式的XML以表格的形式显示出来,思路很简单,就是把XML文件导入Dataset 即可。可当我想XML文件内容读到一个string变量内,再把这个变量到到dataset对象内的时候,遇到了一些难题。dataset竟然没有提供直接从string导入的操作。在网上查询无果的情况下,自己试着写一写了。下面我就把思路写下来,供大家参考。
在DataSet对象中,将外部符合XML格式的对象导入到本身的方法是LoadXml,这个方法提供了八个重载,归结起来只是对三种对象的操作,分别为XmlReader,TextReader,Stream,没有针对string对象的,只有从这三个对象下手了。首先看看stream类,一个提供流操作的基类,其派生类中最常使用的就是FileStream,但它是针对文件的,并不提供对字符串的格式化。再看看其它的派生类,查阅MSDN可得知常用的派生类还有 BufferedStream、MemoryStream.BufferedStream的构造函数中需要stream对象,因此这个派生类也不予考虑了。MemoryStream类的构造函数参数需要byte[]类型的,这个倒是可以考虑考虑,可以把string变量转化成byte[]类型的,通过实践可以把一个string类型的变量导入到DataSet对象中的。下面是代码片段:
byte [] xmlByte = ascII.GetBytes(xmlString);
MemoryStream ms = new MemoryStream(xmlByte);
DataSet ds = new DataSet();
ds.ReadXml(ms);
接下来,再看看关于TextReader对象的重载方式。参阅MSDN,它有两个派生类 StreamReader、StringReader,第一眼就知道要使用stringReader类,而且它的构造函数只要传递一个string对象即可,这要比MemoryStream方便多了,以下是代码:
DataSet ds = new DataSet();
ds.ReadXml(sr);
至于用XmlReader对象的重载方式,在其构造函数中传入TextReader对象即可,代码略。