Partager via


XmlWriter.WriteAttributes(XmlReader, Boolean) Méthode

Définition

En cas de substitution dans une classe dérivée, écrit tous les attributs trouvés à la position actuelle dans XmlReader.

public:
 virtual void WriteAttributes(System::Xml::XmlReader ^ reader, bool defattr);
public virtual void WriteAttributes (System.Xml.XmlReader reader, bool defattr);
abstract member WriteAttributes : System.Xml.XmlReader * bool -> unit
override this.WriteAttributes : System.Xml.XmlReader * bool -> unit
Public Overridable Sub WriteAttributes (reader As XmlReader, defattr As Boolean)

Paramètres

reader
XmlReader

XmlReader à partir duquel les attributs doivent être copiés.

defattr
Boolean

true pour copier les attributs par défaut à partir de XmlReader ; sinon, false.

Exceptions

reader a la valeur null.

Le lecteur n'est pas placé sur un nœud element, attribute ou XmlDeclaration.

Une méthode XmlWriter a été appelée avant la fin d’une opération asynchrone précédente. Dans ce cas, l’exception InvalidOperationException est levée avec le message « Une opération asynchrone est déjà en cours ».

Exemples

L’exemple suivant copie tous les éléments dans la sortie, modifie les noms des balises en majuscules et copie tous les attributs inchangés.

#using <System.Xml.dll>

using namespace System;
using namespace System::IO;
using namespace System::Xml;
void main()
{
   XmlReader^ reader = XmlReader::Create( L"test1.xml" );
   XmlWriterSettings^ settings = gcnew XmlWriterSettings;
   settings->Indent = true;
   XmlWriter^ writer = XmlWriter::Create( Console::Out );
   while ( reader->Read() )
   {
      if ( reader->NodeType == XmlNodeType::Element )
      {
         writer->WriteStartElement( reader->Name->ToUpper() );
         writer->WriteAttributes( reader, false );
         if ( reader->IsEmptyElement )
                  writer->WriteEndElement();
      }
      else
      if ( reader->NodeType == XmlNodeType::EndElement )
      {
         writer->WriteEndElement();
      }
   }

   writer->Close();
   reader->Close();
}
using System;
using System.IO;
using System.Xml;

public class Sample {

  public static void Main() {

    XmlReader reader = XmlReader.Create("test1.xml");
    XmlWriterSettings settings = new XmlWriterSettings();
    settings.Indent = true;
    XmlWriter writer = XmlWriter.Create(Console.Out);

    while (reader.Read()) {
      if (reader.NodeType == XmlNodeType.Element) {
        writer.WriteStartElement(reader.Name.ToUpper());
        writer.WriteAttributes(reader, false);
        if (reader.IsEmptyElement) writer.WriteEndElement();
      }
      else if (reader.NodeType == XmlNodeType.EndElement) {
        writer.WriteEndElement();
      }
    }
    writer.Close();
    reader.Close();
  }
}
Option Strict
Option Explicit

Imports System.IO
Imports System.Xml

Public Class Sample
    
  Public Shared Sub Main()

    Dim reader As XmlReader = XmlReader.Create("test1.xml")
    Dim settings As XmlWriterSettings = new XmlWriterSettings()
    settings.Indent = true
    Dim writer As XmlWriter = XmlWriter.Create(Console.Out)
        
      While reader.Read()
          If reader.NodeType = XmlNodeType.Element Then
              writer.WriteStartElement(reader.Name.ToUpper())
              writer.WriteAttributes(reader, False)
              If reader.IsEmptyElement Then
                 writer.WriteEndElement()
              End If
          Else
              If reader.NodeType = XmlNodeType.EndElement Then
                  writer.WriteEndElement()
              End If
          End If
      End While
      writer.Close()
      reader.Close()

    End Sub
End Class

L’exemple utilise le fichier, test1.xmlcomme entrée.

<test a="1" b="2">
    <item c="3" d="4" e="5" f="6"/>
</test>

Remarques

Si le lecteur est positionné sur un element nœud WriteAttributes copie tous les attributs contenus. Si le lecteur est positionné sur un attribute nœud, cette méthode écrit l’attribut actuel, puis le reste des attributs jusqu’à la balise de fermeture de l’élément. Si le lecteur est positionné sur un XmlDeclaration nœud, cette méthode écrit tous les attributs de la déclaration. Si le lecteur est positionné sur un autre type de nœud, cette méthode lève un XmlException.

Si cette méthode est appelée à l’aide XmlValidatingReader, pour garantir un contenu XML bien formé (qui a été développé à partir des entités) qui peut entraîner un remplacement d’un document non valide lors de l’écriture. Par exemple, si un attribut inclut une &gt; entité qui a été développée, pour garantir qu’un document bien formé, le > développé est remplacé lorsqu’il est écrit avec &gt;.

Pour obtenir la version asynchrone de cette méthode, consultez WriteAttributesAsync.

S’applique à