0

我正在研究一组将用于序列化为 XML 的类。XML 不是由我控制的,而且组织得很好。不幸的是,有几组嵌套节点,其中一些的目的只是为了保存它们的子节点的集合。根据我目前对 XML 序列化的了解,这些节点需要另一个类。

有没有办法让一个类序列化到一组 XML 节点而不是一个。因为我觉得我像泥一样清楚,所以说我们有xml:

<root>
    <users>
        <user id="">
            <firstname />
            <lastname />
            ...
        </user>
        <user id="">
            <firstname />
            <lastname />
            ...
        </user>
    </users>
    <groups>
        <group id="" groupname="">
            <userid />
            <userid />
        </group>
        <group id="" groupname="">
            <userid />
            <userid />
        </group>
    </groups>
</root>

理想情况下,最好是 3 节课。root具有集合usergroup对象的类。但是,我能想到的最好的办法是,我需要一个用于rootusers、和的类user,其中和分别只包含 和 的集合,并且包含一个、和对象。groupsgroupusersgroupsusergrouprootusersgroups

有谁比我更懂?(别说谎,我知道有)。

4

3 回答 3

6

您不使用XmlSerializer吗?它非常好,让做这样的事情变得非常容易(我经常使用它!)。

你可以简单地用一些属性装饰你的类属性,其余的都为你完成。

您是否考虑过使用 XmlSerializer 或者是否有特殊原因?

这是使上述序列化(两种方式)所需的所有工作的代码片段:

[XmlArray("users"),
XmlArrayItem("user")]
public List<User> Users
{
    get { return _users; }
}
于 2008-09-16T20:43:18.677 回答
0

您只需要将用户定义为用户对象的数组。XmlSerializer 将为您适当地呈现它。

有关示例,请参见此链接:http: //www.informit.com/articles/article.aspx?p=23105 &seqNum=4

此外,我建议使用 Visual Studio 生成 XSD 并使用命令行实用程序 XSD.EXE 为您吐出类层次结构,如http://quickstart.developerfusion.co.uk/quickstart/howto/doc/xmlserialization /XSDToCls.aspx

于 2008-09-16T20:47:20.820 回答
0

我在那天写这门课是为了做我认为的事情,类似于你想做的事情。您可以对希望序列化为 XML 的对象使用此类的方法。例如,给定一个员工...

使用实用程序;使用 System.Xml.Serialization;

[XmlRoot("Employee")] public class Employee { private String name = "Steve";

 [XmlElement("Name")]
 public string Name { get { return name; } set{ name = value; } }

 public static void Main(String[] args)
 {
      Employee e = new Employee();
      XmlObjectSerializer.Save("c:\steve.xml", e);
 }

}

此代码应输出:

<Employee>
  <Name>Steve</Name>
</Employee>

对象类型 (Employee) 必须是可序列化的。尝试 [Serializable(true)]。我在某个地方有此代码的更好版本,我在编写它时只是在学习。不管怎样,看看下面的代码。我在某个项目中使用它,所以它肯定有效。

using System;
using System.IO;
using System.Xml.Serialization;

namespace Utilities
{
    /// <summary>
    /// Opens and Saves objects to Xml
    /// </summary>
    /// <projectIndependent>True</projectIndependent>
    public static class XmlObjectSerializer
    {
        /// <summary>
        /// Serializes and saves data contained in obj to an XML file located at filePath <para></para>        
        /// </summary>
        /// <param name="filePath">The file path to save to</param>
        /// <param name="obj">The object to save</param>
        /// <exception cref="System.IO.IOException">Thrown if an error occurs while saving the object. See inner exception for details</exception>
        public static void Save(String filePath, Object obj)
        {
            // allows access to the file
            StreamWriter oWriter =  null;

            try
            {
                // Open a stream to the file path
                 oWriter = new StreamWriter(filePath);

                // Create a serializer for the object's type
                XmlSerializer oSerializer = new XmlSerializer(obj.GetType());

                // Serialize the object and write to the file
                oSerializer.Serialize(oWriter.BaseStream, obj);
            }
            catch (Exception ex)
            {
                // throw any errors as IO exceptions
                throw new IOException("An error occurred while saving the object", ex);
            }
            finally
            {
                // if a stream is open
                if (oWriter != null)
                {
                    // close it
                    oWriter.Close();
                }
            }
        }

        /// <summary>
        /// Deserializes saved object data of type T in an XML file
        /// located at filePath        
        /// </summary>
        /// <typeparam name="T">Type of object to deserialize</typeparam>
        /// <param name="filePath">The path to open the object from</param>
        /// <returns>An object representing the file or the default value for type T</returns>
        /// <exception cref="System.IO.IOException">Thrown if the file could not be opened. See inner exception for details</exception>
        public static T Open<T>(String filePath)
        {
            // gets access to the file
            StreamReader oReader = null;

            // the deserialized data
            Object data;

            try
            {
                // Open a stream to the file
                oReader = new StreamReader(filePath);

                // Create a deserializer for the object's type
                XmlSerializer oDeserializer = new XmlSerializer(typeof(T));

                // Deserialize the data and store it
                data = oDeserializer.Deserialize(oReader.BaseStream);

                //
                // Return the deserialized object
                // don't cast it if it's null
                // will be null if open failed
                //
                if (data != null)
                {
                    return (T)data;
                }
                else
                {
                    return default(T);
                }
            }
            catch (Exception ex)
            {
                // throw error
                throw new IOException("An error occurred while opening the file", ex);
            }
            finally
            {
                // Close the stream
                oReader.Close();
            }
        }
    }
}
于 2008-09-16T21:21:36.803 回答