我正在使用包含无界集合的大型xml文件。我们的想法是使用XmlReader读取文件并将内部xml反序列化为对象并进行进一步处理。
XML结构是这样的:
<Basket xmlns="http://AppleFarm.com/Basket">
<AppleCount>10000</AppleCount>
<Apples>
<Apple><ID>1</ID><Color>Red</Color></Apple>
<Apple><ID>2</ID><Color>Green</Color></Apple>
...
<Apple><ID>10000</ID><Color>Green</Color></Apple>
</Apples>
</Basket>
使用XMLReader环绕XMLTextReader来读取文件,一切顺利。但是,当我尝试将单个apple反序列化为一个对象时,它会抛出InvaildOperationException。
任何人都知道这个问题是什么?有没有更好的方法呢?
以下是代码片段
//Deserialize code
public object Deserialize(XmlDocument doc, Type type){
using(XmlNodeReader reader - new XmlNodeReader(doc.DocumentElement)){
XmlReaderSetting settings = new XmlReaderSettings();
settings.ValidationType = ValidationType.None;
using(XmlReader xReader = XmlReader.Create(reader, settings)){
XmlSerializer serializer = new XmlSerializer(type);
object obj = serializer.Deserialize(xReader);
}
}
}
public void GetApples(string filepath){
XmlTextReader reader = new XmlTextReader(filepath);
while(reader.Read()){
while(reader.NoteType == XmlNodeType.Element &&
reader.Name == "Apple"){
XmlDocument doc = new XmlDocument();
doc.LoadXml(reader.ReadOuterXml());
Apple a = (Apple)Deserialize(doc, typeof(Apple));
//...
}
}
}
//Deserialize code end
//Apple class
[System.CodeDom.Compiler.GeneratedCodeAttribute("xsd", "2.0.50727.3038")]
[System.SerializableAttribute()]
[System.Diagnostics.DebuggerStepThroughAttribute()]
[System.ComponentModel.DesignerCategoryAttribute("code")]
[System.XmlSerialization.XmlTypeAttribute(Namespace="http://AppleFarm.com/Basket")]
public partial class Apple{
private string idField;
private string colorField;
public string Id{
get{ return this.idField; }
set{ this.idField = value; }
}
public string Color{
get { return this.colorField; }
set { this.colorField = value; }
}
}
//Apple class end
答案 0 :(得分:1)
XML反序列化需要第一行
<?xml version="1.0" encoding="utf-8"?>
如果要将xml文档的一部分转换为Object,则必须将此行附加到部分XML的顶部。
另外你需要用XmlRootAttribute来装饰Apple类,其中ElementName将是'Apple'
本文介绍如何设置XmlRootAtrribute http://msdn.microsoft.com/en-us/library/system.xml.serialization.xmlrootattribute.aspx
希望这会有所帮助
Reagards。