2009-04-15 24 views

Respuesta

27

Eche un vistazo al método XDocument.WriteTo; por ejemplo:

using (MemoryStream ms = new MemoryStream()) 
{ 
    XmlWriterSettings xws = new XmlWriterSettings(); 
    xws.OmitXmlDeclaration = true; 
    xws.Indent = true; 

    using (XmlWriter xw = XmlWriter.Create(ms, xws)) 
    { 
     XDocument doc = new XDocument(
      new XElement("Child", 
       new XElement("GrandChild", "some content") 
      ) 
     ); 
     doc.WriteTo(xw); 
    } 
} 
+5

O .Save - pero el ejemplo tiene ;-P –

+2

@Marc ¿Cuál es la diferencia entre WriteTo() y Save()? –

+4

@Daniel Fortunov: .Save proporciona más sobrecargas, pero todas terminan llamando a .WriteTo – dtb

24

En .NET 4 y posteriores, se puede guardar a un MemoryStream:

Stream stream = new MemoryStream(); 
doc.Save(stream); 
// Rewind the stream ready to read from it elsewhere 
stream.Position = 0; 

En .NET 3.5 y anteriores, lo que se necesita para crear un XmlWriter basado en un MemoryStream y guardar para eso, como se muestra en dtb's answer.

+0

Me pregunto si ambos enfoques agregan \ r \ n y espacios en blanco. Sería genial tener una opción fácil aquí (en lugar de sobrecargar el XmlWriter existente) – beanmf

0
XDocument doc = new XDocument(
    new XElement(C_ROOT, 
     new XElement("Child"))); 
using (var stream = new MemoryStream()) 
{ 
    doc.Save(stream); 
    stream.Seek(0, SeekOrigin.Begin); 
}