XML-Dokumente erstellen mit XmlWriter

Lies diesen Artikel und viele weitere mit einem kostenlosen, einwöchigen Testzugang.

Im Artikel “XML-Dokumente schnell lesen mit XmlReader” haben Sie die Klasse XmlReader kennengelernt, mit der Sie schnell durch XML-Dokumente navigieren können. Damit können Sie zum Beispiel Exporte aus anderen Anwendungen in Ihre .NET-Anwendung importieren. Aber was, wenn Sie selbst einmal einen Export mit Ihren Daten im XML-Format bereitstellen wollen Dazu gibt es eine passende Klasse namens XmlWriter. Wie Sie damit XML-Dokumente erstellen und mit den gewünschten Daten füllen, erfahren Sie im vorliegenden Artikel.

Namespace System.Xml referenzieren

Genau wie die Klasse XmlReader ist auch XmlWriter Bestandteil des Namespaces System.Xml. Diesen referenzieren wir deshalb wie folgt im Kopf der Code behind-Klasse unseres Beispielfensters MainWindow.xaml:

Imports System.Xml

Leeres XML-Dokument erstellen mit Create

Um ein XML-Dokument als Datei zu erstellen, rufen Sie die Methode Create des XmlWriter-Objekts auf und übergeben dieser den Pfad der zu erstellenden XML-Datei. Wenn Sie einfach nur den Dateinamen angeben, wird die Datei im gleichen Verzeichnis erstellt wie die .exe-Datei des Projekts:

Dim objWriter As XmlWriter
objWriter = XmlWriter.Create("XmlWriter.xml")
objWriter.Close()

Dies legt allerdings nur ein leeres Dokument an.

XML-Dokument mit Element erstellen

Um ein Dokument mit dem Prolog und einem ersten Element zu erstellen, bedarf es einiger weiterer Zeilen. Die Methoden Write-StartDocument und WriteEndDokument starten den Schreibprozess und beenden diesen wieder. Die Methode WriteStart-Element fügt ein Starttag namens Bestellverwaltung hinzu und WriteEndElement schließt das Element mit dem Endtag ab. Dabei müssen Sie WriteEndElement keinen Parameter mehr übergeben – die Methode bezieht sich immer auf das zuletzt geöffnete Starttag:

Private Sub btnDokumentMitElementErstellen_Click(sender As Object, e As RoutedEventArgs)
     Dim objWriter As XmlWriter
     objWriter = XmlWriter.Create("XmlWriter.xml", objSettings)
     objWriter.WriteStartDocument()
     objWriter.WriteStartElement("Bestellverwaltung")
     objWriter.WriteEndElement()
     objWriter.WriteEndDocument()
     objWriter.Close()
End Sub

Das Ergebnis ist das folgende XML-Dokument:

<xml version="1.0" encoding="utf-8"><Bestellverwaltung />

Hier finden wir keinen Zeilenumbruch, was wir als Erstes ändern möchten

Ende des frei verfügbaren Teil. Wenn Du mehr lesen möchtest, hole Dir ...

Testzugang

eine Woche kostenlosen Zugriff auf diesen und mehr als 1.000 weitere Artikel

diesen und alle anderen Artikel mit dem Jahresabo

Schreibe einen Kommentar