我有xml(我无法控制),我需要使用XmlSerializer反序列化。我的麻烦是我需要在一个列表中保留两个不同标签之间的顺序。让我举个例子:
<users>
<luser>..some more elements..</luser>
<luser>..some more elements..</luser>
<admin>..different elements than in luser</admin>
<luser>..some more elements..</luser>
<admin>..different elements than in luser</admin>
<luser>..some more elements..</luser>
<admin>..different elements than in luser</admin>
<users>
现在,如果我以直截了当的方式对其进行反序列化,我最终得到两个列表,一个用于lusers,另一个用于管理员。但是,它们出现的顺序是隐式ID! (当然,这应该是xml中的一个属性或元素,但实际上并非如此)
我试图制作像这样的元素
[XmlElement("luser"),XmlElement("admin")]
public List<Person> Person { get; set; }
与
public class Person
{
public Luser Luser { get; set; }
public Admin Admin { get; set; }
}
计划是检查列表以查看条目是luser还是admin,并让人员包装器维护元素的顺序。但是,单个属性上的多个XmlElement属性似乎是非法的。
另一个可接受的解决方案是最终得到两个列表,但每个列表中的每个条目都有一个我可以用来获取原始订单的ID。
我希望它尽可能干净。之后搜索xml以查找订单,手动提取标签等,这是我应该避免做的事情。作为最后的手段。
答案 0 :(得分:4)
当然应该是属性......
然后尽快将其设为属性。然后使用结果。
var doc = XDocument.Load(...);
var fixeruppers = doc
.Descendants("users")
.Elements()
.ToList(); // isolate us from any movements in the doc
int id = 1; // base
foreach (var fixer in fixeruppers)
fixer.SetAttributeValue("Id", id++);
XmlReader readerForDeserialize = doc.CreateReader();
答案 1 :(得分:-2)
以下将指示顺序(顺序:= value),它不会改变类的序列化方式。
Imports System.Runtime.Serialization
Imports System.ServiceModel
<DataContract()> _
Public Class MyClass
<DataMember(order:=1)> _
Public Property SomeData() As String
<DataMember(order:=2)> _
Public Property SomeOtherData() As String
End Class