反序列化XML数组,其中Root是数组,元素不遵循约定
我得到的XML是由外部源提供的,所以我没有能力轻松地重新格式化它。 我想在我的实体上使用xml属性,而不必编写知道如何格式化XML和实体的linq查询。 这是一个例子:
2013-2 Spring 2013 2013-3 Summer 2013 Jun&Jul
我知道XMLSerializer需要ArrayOfTerm而不是TERMS,但是我可以调整我的实体以使用不同的元素名称和xml属性,例如:
public class TermData { [XmlArray("TERMS")] [XmlArrayItem("TERM")] public List terms; } public class Term { [XmlElement("ID")] public string id; [XmlElement("DESC")] public string desc; }
我正在反序列化数据,如下所示:
TermData data; XmlSerializer serializer = new XmlSerializer(typeof(TermData)); using (StringReader reader = new StringReader(xml)) { data = (TermData)serializer.Deserialize(reader); } return View(data.terms);
我面临的问题是TERMS是根和数组本身。 如果XML的根元素不是数组,我可以编辑我的TermData类,它会正确地反序列化(已经过测试)。
[XmlRoot("ROOT")] public class TermData { [XmlArray("TERMS")] [XmlArrayItem("TERM")] public List terms; }
请注意,使用TERMS作为XMLRoot不起作用。 现在,我的代码正在抛出
InvalidOperationException: There is an error in XML document (2,2). InnerException: "<TERMS xmlns=" was not expected.
这会让我相信XML没有正确格式化,但根据我的理解,我给出的示例是完全有效的XML。
如果我可以编辑源xml,这将是微不足道的,但是可能会有大量其他响应,我需要能够灵活地为我得到的任何东西。 我要确认的是XMLSerializer是否可以支持这种类型的XML结构。 我已经测试了几乎所有内容,并且无法在不编辑XML的情况下进行反序列化。 如果我不必定义一个包装类(TermData)来保存列表也很方便,但是这似乎只有在xml遵循序列化器的命名约定(ArrayOfTerm等)时才有效。
也许你可以尝试:
[XmlRoot("TERMS")] public class TermData { public TermData() { terms = new List(); } [XmlElement("TERM")] public List terms{get;set;} } public class Term { [XmlElement("ID")] public string id{get;set;} [XmlElement("DESC")] public string desc{get;set;} }
希望这会有所帮助,