XmlWriter.WriteAttributes(XmlReader, Boolean) Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
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.xml
comme 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 >
entité qui a été développée, pour garantir qu’un document bien formé, le > développé est remplacé lorsqu’il est écrit avec >
.
Pour obtenir la version asynchrone de cette méthode, consultez WriteAttributesAsync.