如何在C#中生成有效的XML?
这取决于场景。XmlSerializer当然是一种方法,并且具有直接映射到对象模型的优势。在.NET 3.5 XDocument等方面也非常友好。如果尺寸很大,那XmlWriter就是您的朋友。
XmlSerializer
XDocument
XmlWriter
对于一个XDocument例子:
Console.WriteLine( new XElement("Foo", new XAttribute("Bar", "some & value"), new XElement("Nested", "data")));
或与XmlDocument:
XmlDocument
XmlDocument doc = new XmlDocument(); XmlElement el = (XmlElement)doc.AppendChild(doc.CreateElement("Foo")); el.SetAttribute("Bar", "some & value"); el.AppendChild(doc.CreateElement("Nested")).InnerText = "data"; Console.WriteLine(doc.OuterXml);
如果您正在写入 大量 数据,那么任何DOM方法(例如XmlDocument/ XDocument等)都将迅速占用大量内存。因此,如果您要从CSV编写一个100 MB的XML文件,则可以考虑XmlWriter;这是更原始的(一次写入型firehose),但是非常有效(在这里想象一个大循环):
XmlWriter writer = XmlWriter.Create(Console.Out); writer.WriteStartElement("Foo"); writer.WriteAttributeString("Bar", "Some & value"); writer.WriteElementString("Nested", "data"); writer.WriteEndElement();
最后,通过XmlSerializer:
[Serializable] public class Foo { [XmlAttribute] public string Bar { get; set; } public string Nested { get; set; } } ... Foo foo = new Foo { Bar = "some & value", Nested = "data" }; new XmlSerializer(typeof(Foo)).Serialize(Console.Out, foo);
这是映射到类等的不错模型。但是,如果您执行简单的操作(或者所需的XML确实与对象模型没有直接关联),则可能会过大。另一个问题XmlSerializer是,它不喜欢序列化不可变类型:所有内容都必须具有公共的getter 和 setter(除非您自己通过实现来完成所有工作IXmlSerializable,在这种情况下,您使用不会有太多收获XmlSerializer)。
IXmlSerializable