문제

다음 XML이 주어지면 :

<?xml version="1.0"?>
<user_list>
   <user>
      <id>1</id>
      <name>Joe</name>
   </user>
   <user>
      <id>2</id>
      <name>John</name>
   </user>
</user_list>

그리고 다음 수업 :

public class User {
   [XmlElement("id")]
   public Int32 Id { get; set; }

   [XmlElement("name")]
   public String Name { get; set; }
}

사용할 수 있습니까? XmlSerializer XML을 a로 삼아야합니다 List<User> ? 그렇다면 어떤 유형의 추가 속성을 사용해야합니까? XmlSerializer 사례?

배열 ( User[] 조금 덜 선호하는 경우) 허용 가능합니다.

도움이 되었습니까?

해결책

당신은 할 수 있습니다 캡슐화 사소한 목록 :

using System;
using System.Collections.Generic;
using System.Xml.Serialization;

[XmlRoot("user_list")]
public class UserList
{
    public UserList() {Items = new List<User>();}
    [XmlElement("user")]
    public List<User> Items {get;set;}
}
public class User
{
    [XmlElement("id")]
    public Int32 Id { get; set; }

    [XmlElement("name")]
    public String Name { get; set; }
}

static class Program
{
    static void Main()
    {
        XmlSerializer ser= new XmlSerializer(typeof(UserList));
        UserList list = new UserList();
        list.Items.Add(new User { Id = 1, Name = "abc"});
        list.Items.Add(new User { Id = 2, Name = "def"});
        list.Items.Add(new User { Id = 3, Name = "ghi"});
        ser.Serialize(Console.Out, list);
    }
}

다른 팁

당신이 장식한다면 User 수업 XmlType 필요한 대문자와 일치하기 위해 :

[XmlType("user")]
public class User
{
   ...
}

그럼 XmlRootAttributeXmlSerializer CTOR는 원하는 뿌리를 제공하고 List <>에 직접 읽을 수 있습니다.

    // e.g. my test to create a file
    using (var writer = new FileStream("users.xml", FileMode.Create))
    {
        XmlSerializer ser = new XmlSerializer(typeof(List<User>),  
            new XmlRootAttribute("user_list"));
        List<User> list = new List<User>();
        list.Add(new User { Id = 1, Name = "Joe" });
        list.Add(new User { Id = 2, Name = "John" });
        list.Add(new User { Id = 3, Name = "June" });
        ser.Serialize(writer, list);
    }

...

    // read file
    List<User> users;
    using (var reader = new StreamReader("users.xml"))
    {
        XmlSerializer deserializer = new XmlSerializer(typeof(List<User>),  
            new XmlRootAttribute("user_list"));
        users = (List<User>)deserializer.Deserialize(reader);
    }

크레딧 : 기반 대답 ~에서 YK1.

예, 목록을 직렬화하고 실시 할 것입니다. 의심스러운 경우 [xmlarray] 속성을 사용해야합니다.

[Serializable]
public class A
{
    [XmlArray]
    public List<string> strings;
}

Serialize () 및 Deserialize () 모두에서 작동합니다.

더 나은 방법을 찾았다 고 생각합니다. 당신은 당신의 수업에 속성을 넣을 필요가 없습니다. 일반화와 사형화를위한 두 가지 방법을 만들어 일반 목록을 매개 변수로 사용했습니다.

살펴보십시오 (나를 위해 작동합니다) :

private void SerializeParams<T>(XDocument doc, List<T> paramList)
    {
        System.Xml.Serialization.XmlSerializer serializer = new System.Xml.Serialization.XmlSerializer(paramList.GetType());

        System.Xml.XmlWriter writer = doc.CreateWriter();

        serializer.Serialize(writer, paramList);

        writer.Close();           
    }

private List<T> DeserializeParams<T>(XDocument doc)
    {
        System.Xml.Serialization.XmlSerializer serializer = new System.Xml.Serialization.XmlSerializer(typeof(List<T>));

        System.Xml.XmlReader reader = doc.CreateReader();

        List<T> result = (List<T>)serializer.Deserialize(reader);
        reader.Close();

        return result;
    }

따라서 원하는 목록을 직렬화 할 수 있습니다! 매번 목록 유형을 지정할 필요가 없습니다.

        List<AssemblyBO> list = new List<AssemblyBO>();
        list.Add(new AssemblyBO());
        list.Add(new AssemblyBO() { DisplayName = "Try", Identifier = "243242" });
        XDocument doc = new XDocument();
        SerializeParams<T>(doc, list);
        List<AssemblyBO> newList = DeserializeParams<AssemblyBO>(doc);

예, <>을 목록으로 삼아야합니다. 배열에 보관할 필요가없고 목록에 랩/캡슐화 할 필요가 없습니다.

public class UserHolder
{
    private List<User> users = null;

    public UserHolder()
    {
    }

    [XmlElement("user")]
    public List<User> Users
    {
        get { return users; }
        set { users = value; }
    }
}

코드를 제외하고,

XmlSerializer xs = new XmlSerializer(typeof(UserHolder));
UserHolder uh = (UserHolder)xs.Deserialize(new StringReader(str));

목록에 대해 확실하지 않습니다u003CT> 그러나 배열은 확실히 가능합니다. 그리고 약간의 마술은 다시 목록에 쉽게 얻을 수있게합니다.

public class UserHolder {
   [XmlElement("list")]
   public User[] Users { get; set; }

   [XmlIgnore]
   public List<User> UserList { get { return new List<User>(Users); } }
}

어때

XmlSerializer xs = new XmlSerializer(typeof(user[]));
using (Stream ins = File.Open(@"c:\some.xml", FileMode.Open))
foreach (user o in (user[])xs.Deserialize(ins))
   userList.Add(o);    

특히 화려하지는 않지만 작동해야합니다.

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top