Wenn die obige Beautify-Methode für einen Knoten aufgerufen wird XmlDocument
, der bereits einen untergeordneten XmlProcessingInstruction
Knoten enthält , wird die folgende Ausnahme ausgelöst:
XML-Deklaration kann nicht geschrieben werden. Die WriteStartDocument-Methode hat es bereits geschrieben.
Dies ist meine modifizierte Version des Originals, um die Ausnahme zu beseitigen:
private static string beautify(
XmlDocument doc)
{
var sb = new StringBuilder();
var settings =
new XmlWriterSettings
{
Indent = true,
IndentChars = @" ",
NewLineChars = Environment.NewLine,
NewLineHandling = NewLineHandling.Replace,
};
using (var writer = XmlWriter.Create(sb, settings))
{
if (doc.ChildNodes[0] is XmlProcessingInstruction)
{
doc.RemoveChild(doc.ChildNodes[0]);
}
doc.Save(writer);
return sb.ToString();
}
}
Es funktioniert jetzt für mich, wahrscheinlich müssten Sie alle untergeordneten Knoten nach dem XmlProcessingInstruction
Knoten durchsuchen, nicht nur den ersten?
Update April 2015:
Da ich einen anderen Fall hatte, in dem die Codierung falsch war, suchte ich nach Möglichkeiten, UTF-8 ohne Stückliste zu erzwingen. Ich habe diesen Blog-Beitrag gefunden und eine darauf basierende Funktion erstellt:
private static string beautify(string xml)
{
var doc = new XmlDocument();
doc.LoadXml(xml);
var settings = new XmlWriterSettings
{
Indent = true,
IndentChars = "\t",
NewLineChars = Environment.NewLine,
NewLineHandling = NewLineHandling.Replace,
Encoding = new UTF8Encoding(false)
};
using (var ms = new MemoryStream())
using (var writer = XmlWriter.Create(ms, settings))
{
doc.Save(writer);
var xmlString = Encoding.UTF8.GetString(ms.ToArray());
return xmlString;
}
}