XmlDocument.Save Método

Definición

Guarda el documento XML en la ubicación especificada.

Sobrecargas

Save(Stream)

Guarda el documento XML en el flujo especificado.

Save(TextWriter)

Guarda el documento XML en el TextWriter especificado.

Save(String)

Guarda el documento XML en el archivo especificado. Si existe el archivo especificado, este método lo sobrescribe.

Save(XmlWriter)

Guarda el documento XML en el XmlWriter especificado.

Save(Stream)

Guarda el documento XML en el flujo especificado.

C#
public virtual void Save (System.IO.Stream outStream);

Parámetros

outStream
Stream

Secuencia en la que se desea guardar.

Excepciones

La operación no generarái un documento XML bien formado (por ejemplo, ningún documento duplicado o declaraciones XML duplicadas).

Comentarios

El espacio en blanco solo se conserva si PreserveWhitespace se establece en true.

XmlDeclaration del objeto actual XmlDocument determina el atributo de codificación en el documento guardado. El valor del atributo de codificación se toma de la XmlDeclaration.Encoding propiedad . XmlDocument Si no tiene un xmlDeclaration o si xmlDeclaration no tiene un atributo de codificación, el documento guardado tampoco tendrá uno.

Cuando se guarda el documento, se generan atributos xmlns para conservar correctamente la identidad del nodo (nombre local + URI de espacio de nombres). Por ejemplo, el siguiente código de C#

C#
XmlDocument doc = new XmlDocument();  
doc.AppendChild(doc.CreateElement("item","urn:1"));  
doc.Save(Console.Out);  

genera este atributo <item xmls="urn:1"/>xmls .

Este método es una extensión de Microsoft al Modelo de objetos de documento (DOM).

Tenga en cuenta que solo el Save método aplica un documento XML bien formado. Todas las demás Save sobrecargas solo garantizan un fragmento bien formado.

Se aplica a

.NET 7 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1
UWP 10.0

Save(TextWriter)

Guarda el documento XML en el TextWriter especificado.

C#
public virtual void Save (System.IO.TextWriter writer);

Parámetros

writer
TextWriter

TextWriter en el que se desea guardar.

Excepciones

La operación no generarái un documento XML bien formado (por ejemplo, ningún documento duplicado o declaraciones XML duplicadas).

Comentarios

La codificación de TextWriter determina la codificación que se escribe (la codificación del nodo XmlDeclaration se reemplaza por la codificación de TextWriter). Si no se ha especificado ninguna codificación en TextWriter, XmlDocument se guarda sin un atributo de codificación.

Este método es una extensión de Microsoft al Modelo de objetos de documento (DOM).

Tenga en cuenta que solo el Save método aplica un documento XML bien formado. Todas las demás Save sobrecargas solo garantizan un fragmento bien formado.

Se aplica a

.NET 7 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1
UWP 10.0

Save(String)

Guarda el documento XML en el archivo especificado. Si existe el archivo especificado, este método lo sobrescribe.

C#
public virtual void Save (string filename);

Parámetros

filename
String

Ubicación del archivo donde se desea guardar el documento.

Excepciones

La operación no generarái un documento XML bien formado (por ejemplo, ningún documento duplicado o declaraciones XML duplicadas).

Ejemplos

En el ejemplo siguiente se carga XML en un objeto XmlDocument, se modifica y, a continuación, se guarda en un archivo denominado data.xml.

C#
using System;
using System.Xml;

public class Sample {

  public static void Main() {

    // Create the XmlDocument.
    XmlDocument doc = new XmlDocument();
    doc.LoadXml("<item><name>wrench</name></item>");

    // Add a price element.
    XmlElement newElem = doc.CreateElement("price");
    newElem.InnerText = "10.95";
    doc.DocumentElement.AppendChild(newElem);

    // Save the document to a file. White space is
    // preserved (no white space).
    doc.PreserveWhitespace = true;
    doc.Save("data.xml");
  }
}

El archivo data.xml contendrá el siguiente XML: <item><name>wrench</name><price>10.95</price></item>.

Comentarios

El espacio en blanco se conserva en el archivo de salida solo si PreserveWhitespace se establece trueen .

XmlDeclaration del objeto actual XmlDocument determina el atributo de codificación en el documento guardado. El valor del atributo de codificación se toma de la XmlDeclaration.Encoding propiedad . XmlDocument Si no tiene un xmlDeclaration o si xmlDeclaration no tiene un atributo de codificación, el documento guardado tampoco tendrá uno.

Cuando se guarda el documento, se generan atributos xmlns para conservar correctamente la identidad del nodo (nombre local + URI de espacio de nombres). Por ejemplo, el siguiente código de C#

C#
XmlDocument doc = new XmlDocument();  
doc.AppendChild(doc.CreateElement("item","urn:1"));  
doc.Save(Console.Out);  

genera este atributo <item xmls="urn:1"/>xmls .

Este método es una extensión de Microsoft al Modelo de objetos de documento (DOM).

Tenga en cuenta que solo el Save método aplica un documento XML bien formado. Todas las demás Save sobrecargas solo garantizan un fragmento bien formado.

Se aplica a

.NET 7 e outras versións
Produto Versións
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1

Save(XmlWriter)

Guarda el documento XML en el XmlWriter especificado.

C#
public virtual void Save (System.Xml.XmlWriter w);

Parámetros

w
XmlWriter

XmlWriter en el que se desea guardar.

Excepciones

La operación no generarái un documento XML bien formado (por ejemplo, ningún documento duplicado o declaraciones XML duplicadas).

Ejemplos

En el ejemplo siguiente se carga XML en un XmlDocument objeto y se guarda en un archivo.

C#
using System;
using System.Xml;

public class Sample {

  public static void Main() {

    // Create the XmlDocument.
    XmlDocument doc = new XmlDocument();
    doc.LoadXml("<item><name>wrench</name></item>");

   // Add a price element.
   XmlElement newElem = doc.CreateElement("price");
   newElem.InnerText = "10.95";
   doc.DocumentElement.AppendChild(newElem);

   XmlWriterSettings settings = new XmlWriterSettings();
   settings.Indent = true;
   // Save the document to a file and auto-indent the output.
   XmlWriter writer = XmlWriter.Create("data.xml", settings);
    doc.Save(writer);
  }
}

Comentarios

El espacio en blanco solo se conserva si PreserveWhitespace se establece en true.

La codificación de XmlWriter determina la codificación que se escribe (la codificación del nodo XmlDeclaration se reemplaza por la codificación de XmlWriter). Si no se ha especificado ninguna codificación en XmlWriter, XmlDocument se guarda sin un atributo de codificación.

Cuando se guarda el documento, se generan atributos xmlns para conservar correctamente la identidad del nodo (LocalName + NamespaceURI). Por ejemplo, el siguiente código de C#

C#
XmlDocument doc = new XmlDocument();  
doc.AppendChild(doc.CreateElement("item","urn:1"));  
doc.Save(Console.Out);  

genera este atributo xmls:

XML
<item  
    xmls="urn:1"/>  

Este método es una extensión de Microsoft al Modelo de objetos de documento (DOM).

Tenga en cuenta que solo el Save método aplica un documento XML bien formado. Todas las demás Save sobrecargas solo garantizan un fragmento bien formado.

Consulte también

Se aplica a

.NET 7 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1
UWP 10.0