您的位置:首页 > 编程语言 > Delphi

将Delphi的TClientDataSet生成的XML文件转成.Net的DataSet可以识别的格式

2008-11-23 14:29 567 查看
 
费话就不说了,转换方法如下,注意这个方法转换的时候没有生成schema,如果要生成schema稍有点麻烦呢

private string ReadDelphiDataSetToNetDataSet(string vDelphiStr, string vTableName)
        {
            string vResult = vDelphiStr;
            XmlTextReader reader = new XmlTextReader(vDelphiStr, XmlNodeType.Document, null);
            reader.Read();
            MemoryStream stream = new MemoryStream();

            XmlTextWriter vXmlTextWriter = new XmlTextWriter(stream, new UTF8Encoding());
            vXmlTextWriter.Formatting = Formatting.Indented;
            vXmlTextWriter.WriteStartDocument();
            vXmlTextWriter.WriteStartElement("NewDataSet");
           
            while (!reader.EOF)
            {
                if ((reader.NodeType == XmlNodeType.Element && reader.Name.ToUpper() == "ROW"))
                {
                    vXmlTextWriter.WriteStartElement(vTableName);
                    if (reader.HasAttributes)
                    {
                        if (reader.MoveToFirstAttribute())
                        {
                            vXmlTextWriter.WriteElementString(reader.Name, reader.Value);
                            while (reader.MoveToNextAttribute())
                            {
                                vXmlTextWriter.WriteElementString(reader.Name, reader.Value);
                            }
                        }
                        //reader.ReadEndElement();
                    }
                    vXmlTextWriter.WriteEndElement();
                }
                reader.Read();
            }
           
            vXmlTextWriter.WriteEndElement();
            vXmlTextWriter.WriteEndDocument();
            vXmlTextWriter.Flush();
            vXmlTextWriter.Close();
            reader.Close();
            vResult = Encoding.UTF8.GetString(stream.ToArray());
            stream.Close();
            return vResult;           
        }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息