O primeiro exemplo me ajudou a escrever uma função de extensão para uma folha de estilo XSLT , que retorna um conjunto de nós para o processador. Obrigado!
CodeManX
1
Eu diria que, se você substituísse o XmlElementpor var, seria muito mais fácil trabalhar com o primeiro
Robert Perry
1
Trabalhando com um dicionário -> nível 2 acima vem de um dicionário no meu caso (apenas no caso de alguém achar útil) Tentando o primeiro exemplo, tropecei neste erro:
"Este documento já tem um nó 'DocumentElement'."
Eu fui inspirado pela resposta aqui
e editei meu código: (xmlDoc. DocumentElement .AppendChild (body))
//a dictionary:
Dictionary<string, string> Level2Data
{
{"level2", "text"},
{"level2", "other text"},
{"same_level2", "more text"}
}
//xml Decalration:
XmlDocument xmlDoc = new XmlDocument();
XmlDeclaration xmlDeclaration = xmlDoc.CreateXmlDeclaration("1.0", "UTF-8", null);
XmlElement root = xmlDoc.DocumentElement;
xmlDoc.InsertBefore(xmlDeclaration, root);
// add body
XmlElement body = xmlDoc.CreateElement(string.Empty, "body", string.Empty);
xmlDoc.AppendChild(body);
XmlElement body = xmlDoc.CreateElement(string.Empty, "body", string.Empty);
xmlDoc.DocumentElement.AppendChild(body); //without DocumentElement ->ERRforeach (KeyValuePair<string, string> entry in Level2Data)
{
//write to xml: - it works version 1.
XmlNode keyNode = xmlDoc.CreateElement(entry.Key); //open TAB
keyNode.InnerText = entry.Value;
body.AppendChild(keyNode); //close TAB//Write to xmml verdion 2: (uncomment the next 4 lines and comment the above 3 - version 1//XmlElement key = xmlDoc.CreateElement(string.Empty, entry.Key, string.Empty);//XmlText value = xmlDoc.CreateTextNode(entry.Value);//key.AppendChild(value);//body.AppendChild(key);
}
Ambas as versões (1 e 2 dentro do loop foreach) fornecem a saída:
(Nota: a terceira linha "mesmo nível2" no dicionário também pode ser nível2 como as outras, mas eu queria ilustrar a vantagem do dicionário - no meu caso eu precisava de nível2 com nomes diferentes.
Respostas:
A respeito:
#region Using Statements using System; using System.Xml; #endregion class Program { static void Main( string[ ] args ) { XmlDocument doc = new XmlDocument( ); //(1) the xml declaration is recommended, but not mandatory XmlDeclaration xmlDeclaration = doc.CreateXmlDeclaration( "1.0", "UTF-8", null ); XmlElement root = doc.DocumentElement; doc.InsertBefore( xmlDeclaration, root ); //(2) string.Empty makes cleaner code XmlElement element1 = doc.CreateElement( string.Empty, "body", string.Empty ); doc.AppendChild( element1 ); XmlElement element2 = doc.CreateElement( string.Empty, "level1", string.Empty ); element1.AppendChild( element2 ); XmlElement element3 = doc.CreateElement( string.Empty, "level2", string.Empty ); XmlText text1 = doc.CreateTextNode( "text" ); element3.AppendChild( text1 ); element2.AppendChild( element3 ); XmlElement element4 = doc.CreateElement( string.Empty, "level2", string.Empty ); XmlText text2 = doc.CreateTextNode( "other text" ); element4.AppendChild( text2 ); element2.AppendChild( element4 ); doc.Save( "D:\\document.xml" ); } }
(1) Um arquivo XML válido requer uma declaração xml?
(2) Qual é a diferença entre String.Empty e “” (string vazia)?
O resultado é:
<?xml version="1.0" encoding="UTF-8"?> <body> <level1> <level2>text</level2> <level2>other text</level2> </level1> </body>
Mas eu recomendo que você use LINQ to XML, que é mais simples e mais legível como aqui:
#region Using Statements using System; using System.Xml.Linq; #endregion class Program { static void Main( string[ ] args ) { XDocument doc = new XDocument( new XElement( "body", new XElement( "level1", new XElement( "level2", "text" ), new XElement( "level2", "other text" ) ) ) ); doc.Save( "D:\\document.xml" ); } }
fonte
XmlElement
porvar
, seria muito mais fácil trabalhar com o primeiroTrabalhando com um dicionário -> nível 2 acima vem de um dicionário no meu caso (apenas no caso de alguém achar útil) Tentando o primeiro exemplo, tropecei neste erro: "Este documento já tem um nó 'DocumentElement'." Eu fui inspirado pela resposta aqui
e editei meu código: (xmlDoc. DocumentElement .AppendChild (body))
//a dictionary: Dictionary<string, string> Level2Data { {"level2", "text"}, {"level2", "other text"}, {"same_level2", "more text"} } //xml Decalration: XmlDocument xmlDoc = new XmlDocument(); XmlDeclaration xmlDeclaration = xmlDoc.CreateXmlDeclaration("1.0", "UTF-8", null); XmlElement root = xmlDoc.DocumentElement; xmlDoc.InsertBefore(xmlDeclaration, root); // add body XmlElement body = xmlDoc.CreateElement(string.Empty, "body", string.Empty); xmlDoc.AppendChild(body); XmlElement body = xmlDoc.CreateElement(string.Empty, "body", string.Empty); xmlDoc.DocumentElement.AppendChild(body); //without DocumentElement ->ERR foreach (KeyValuePair<string, string> entry in Level2Data) { //write to xml: - it works version 1. XmlNode keyNode = xmlDoc.CreateElement(entry.Key); //open TAB keyNode.InnerText = entry.Value; body.AppendChild(keyNode); //close TAB //Write to xmml verdion 2: (uncomment the next 4 lines and comment the above 3 - version 1 //XmlElement key = xmlDoc.CreateElement(string.Empty, entry.Key, string.Empty); //XmlText value = xmlDoc.CreateTextNode(entry.Value); //key.AppendChild(value); //body.AppendChild(key); }
Ambas as versões (1 e 2 dentro do loop foreach) fornecem a saída:
<?xml version="1.0" encoding="UTF-8"?> <body> <level1> <level2>text</level2> <level2>ther text</level2> <same_level2>more text</same_level2> </level1> </body>
(Nota: a terceira linha "mesmo nível2" no dicionário também pode ser nível2 como as outras, mas eu queria ilustrar a vantagem do dicionário - no meu caso eu precisava de nível2 com nomes diferentes.
fonte