2017-10-06 17 views
2

あなたは現在のXMLの直列化復元で私を助けてもらえ:異なる要素を持つデシリアライズXML

<ObjectList> 
    <Item Attr1="1"/> 
    <Item Attr1="2"/> 
    <DifferentItem Attr2="5"/>  
</ObjectList> 

を、私はこの

public class ObjectList 
{ 
    public List<Item> Items { get; set; } 
    public List<DifferentItem> DifferentItems { get; set; } 
} 

public class Item 
{ 
    public string Attr1 { get; set; } 
} 

public class DifferentItem 
{ 
    public string Attr2 { get; set; } 
} 

のような構造で、それをデシリアライズしたい私は属性を試みたが、失敗しました

[XmlArray("ObjectList")] 
[XmlArrayItem("Item", typeof(Item))] 

どうすればこの問題を解決できますか? おかげで)

答えて

2

は、属性を追加します:あなたはXMLを使用する必要が

public class ObjectList 
{ 
    [XmlElement("Item")] 
    public List<Item> Items { get; set; } 
    [XmlElement("DifferentItem")] 
    public List<DifferentItem> DifferentItems { get; set; } 
} 
0

はクラスやプロパティにXMLをマッピング支援する属性。ここにあなたのXMLで書いたコンソールアプリケーションがあり、それはOKであると解釈されます。 XmlRootとXmlElementの属性を使ってマッピングする方法に注目してください。

public class Program 
{ 
    public static void Main() 
    { 
     var serializer = new XmlSerializer(typeof(ObjectList)); 
     var xml = "<ObjectList><Item Attr1=\"1\" /><Item Attr1=\"2\" /><DifferentItem Attr2=\"5\" /></ObjectList>"; 

     using (var reader = new StringReader(xml)) 
     { 
      var schedule = (ObjectList)serializer.Deserialize(reader); 
     } 
    } 

    [XmlRoot("ObjectList")] 
    public class ObjectList 
    { 
     [XmlElement("Item")] 
     public List<Item> Items { get; set; } 

     [XmlElement("DifferentItem")] 
     public List<DifferentItem> DifferentItems { get; set; } 
    } 

    public class Item 
    { 
     [XmlAttribute("Attr1")] 
     public string Attr1 { get; set; } 
    } 


    public class DifferentItem 
    { 
     [XmlAttribute("Attr2")] 
     public string Attr2 { get; set; } 
    } 
} 
関連する問題