扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
技术工具箱: VB.NET, XML, ADO.NET
ADO.NET提供了一种很好的功能来处理dataset和XML之间的转换。你可以通过VS.NET在XML中形象地创建dataset schema.同一个document type definition(DTD)一样,schema允许你验证和创建XML文件,但相比之下使用。NET类则更加方便,它会带给你更多使用上的灵活性。
然而DTD并非毫无用处。它是广泛应用于非。NET程序中的Internet和数据转换的World Wide Web Consortium(W3C)标准。为了能够实现向后(即非。NET)兼容性,。NET Framework中包含了通过DTDs来验证XML的性能。
然而,就算你需要在一个由Web程序生成的输出XML文件中包含一个DTD,这种情况也是不存在的,或者即使存在,也缺乏可参考的标准文件。
而System.IO.FileStream对象能帮你解决这个问题。你可以创建一个FileStream并将DTD插入你的XML文件中,一个FileStream又引出两种FileStream――它们分别从DTD和dataset中得到。你可以用DTD文件和一些范例XML来设计DataSet schema.VS.NET的Visual Data Set设计界面使这个工作变得很简单,而存储在应用程序文件夹中的DTD文件会被包含在最终形成的XML里。
这个方法用到了许多种不同的FileStreams.一种FileStream (Stream A)中包含有关DTD的信息;另一种FileStream(Stream B)用于创建最终的XML文件。Stream A会流入Stream B中;DataSet会直接流入Stream B中;然后Stream B会关闭并作为一个XML文件存入你的文件系统中。
首先应该准备的是DataSet,你可以创建一个新的基于schema的dataset,然后进行数据绑定。接下来,将DTD文件读取到一个FileStream(Stream A)中。你可以通过创建一个FileStream对象和一个StreamReader对象来实现这一点。通过StreamReader来将文本文件读取到FileStream中: Private Function GetDTD(DTDFilePath as string) _
As IO.FileStream Dim fsDTD As System.IO.FileStream Dim srDTD As IO.StreamReader fsDTD = New IO.FileStream(DTDFilePath, _ IO.FileMode.Open) srDTD = New IO.StreamReader(fsDTD) GetDTD = fsDTD End Function |
调用你之前写好的GetDTD函数,它将返回作为FileStream的DTD文件。然后建立一个和DTD stream同等长度的字节数组,将stream读取到字节数组中,最后关闭它――因为你不再需要用到它了。现在所有的东西都被包含到字节数组中了: dim StreamA as IO.FileStream
StreamA = GetDTD() Dim bytearray(StreamA.Length) As Byte StreamA.Read(bytearray, 0, StreamA.Length) StreamA.Close() |
现在你就可以将DataSet中的数据导入文件中了。DataSet中的WriteXML方法有许多覆盖方法,比如写入一个真实的文件中。此时你可以用将输出文件导入一个FileStream (Stream B)的覆盖方法: myDataSet.WriteXml(StreamB)
不要忘记关闭文件数据流: StreamB.Close
一旦关闭了Stream B,你便可以从文件系统中访问最新的Final.xml文件了。你还可以将这种方法用到其他类型的文本文件中。
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者