反序列化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;} } 

希望这会有所帮助,