我得到的XML是由外部来源提供的,所以我没有能力轻松地重新格式化它。我想在我的实体上使用xml属性,而不必编写知道如何格式化XML和实体的linq查询。这是一个例子:
<?xml version="1.0"?>
<TERMS>
<TERM>
<ID>2013-2</ID>
<DESC>Spring 2013</DESC>
</TERM>
<TERM>
<ID>2013-3</ID>
<DESC>Summer 2013 Jun&Jul</DESC>
</TERM>
</TERMS>
我知道XMLSerializer需要ArrayOfTerm而不是TERMS,但是我可以调整我的实体以使用不同的元素名称和xml属性,例如:
public class TermData
{
[XmlArray("TERMS")]
[XmlArrayItem("TERM")]
public List<Term> 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<Term> 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等)时才有效。 p>
答案 0 :(得分:20)
也许你可以试试:
[XmlRoot("TERMS")]
public class TermData
{
public TermData()
{
terms = new List<Term>();
}
[XmlElement("TERM")]
public List<Term> terms{get;set;}
}
public class Term
{
[XmlElement("ID")]
public string id{get;set;}
[XmlElement("DESC")]
public string desc{get;set;}
}
希望这会有所帮助,