2009-08-04 7 views
8

Używam VSTS2008 + C# + .Net 3.0. Używam poniższego kodu do serializowania XML, a mój obiekt zawiera właściwość typu tablicy, ale generowana jest warstwa dodatkowych elementów (w moim przykładzie, MyInnerObject i MyObject), które chcę usunąć z wygenerowanego pliku XML. Jakieś pomysły?Usuwanie elementów opakowania z szeregowej tablicy XML

Aktualny wygenerowany plik XML,

<?xml version="1.0"?> 
<MyClass xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> 
    <MyObjectProperty> 
    <MyObject> 
     <MyInnerObjectProperty> 
     <MyInnerObject> 
      <ObjectName>Foo Type</ObjectName> 
     </MyInnerObject> 
     </MyInnerObjectProperty> 
    </MyObject> 
    </MyObjectProperty> 
</MyClass> 

Oczekiwany plik XML,

<?xml version="1.0"?> 
<MyClass xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> 
    <MyObjectProperty> 
     <MyInnerObjectProperty> 
      <ObjectName>Foo Type</ObjectName> 
     </MyInnerObjectProperty> 
    </MyObjectProperty> 
</MyClass> 

Aktualny kod,

public class MyClass 
{ 
    private MyObject[] _myObjectProperty; 

    [XmlArrayItemAttribute(IsNullable=false)] 
    public MyObject[] MyObjectProperty 
    { 
     get 
     { 
      return _myObjectProperty; 
     } 
     set 
     { 
      _myObjectProperty = value; 
     } 
    } 
} 
public class MyObject 
{ 
    private MyInnerObject[] _myInnerObjectProperty; 

    [XmlArrayItemAttribute(IsNullable = false)] 
    public MyInnerObject[] MyInnerObjectProperty 
    { 
     get 
     { 
      return _myInnerObjectProperty; 
     } 
     set 
     { 
      _myInnerObjectProperty = value; 
     } 
    } 
} 

public class MyInnerObject 
{ 
    public string ObjectName; 
} 

public class Program 
{ 
    static void Main(string[] args) 
    { 
     XmlSerializer s = new XmlSerializer(typeof(MyClass)); 
     FileStream fs = new FileStream("foo.xml", FileMode.Create); 
     MyClass instance = new MyClass(); 
     instance.MyObjectProperty = new MyObject[1]; 
     instance.MyObjectProperty[0] = new MyObject(); 
     instance.MyObjectProperty[0].MyInnerObjectProperty = new MyInnerObject[1]; 
     instance.MyObjectProperty[0].MyInnerObjectProperty[0] = new MyInnerObject(); 
     instance.MyObjectProperty[0].MyInnerObjectProperty[0].ObjectName = "Foo Type"; 
     s.Serialize(fs, instance); 

     return; 
    } 
} 

Odpowiedz

14

Zamiast

[XmlArrayItemAttribute] 

zastosowanie:

[XmlElement] 

Aby to zorientować się w przyszłości, można uruchomić (z wiersza poleceń VS):

xsd.exe test.xml 
xsd.exe /classes test.xsd 

Generuje test.cs, który zawiera XML można zaszeregować klasę, na podstawie xml. Działa to jeszcze lepiej, jeśli masz plik .xsd w okolicy:

+0

Dzięki Sander, twoje rozwiązanie działa. Czy mógłbyś opisać nieco więcej dlaczego użycie XmlArrayItemAttribute wpływa na wynikowy XML? I dlaczego działa XmlElement? – George2

+2

Jest tylko różnica w nich, która pozwala na użycie obu reprezentacji xml, XmlElement pomija nazwę właściwości i po prostu wyprowadza elementy, XmlArrayItem tworzy tablicę (nazwaną z nazwą właściwości) elementów (nazwaną z podaną nazwą) –

+0

Dzięki Sander , pytanie odpowiedziało. Mam jeszcze jedno pytanie, docenić, jeśli możesz pomóc, http://stackoverflow.com/questions/1227897/adding-an-additional-layer-to-xml-serialization-result-for-an-array – George2