El primer ejemplo me ayudó a escribir una función de extensión para una hoja de estilo XSLT , que devuelve un conjunto de nodos al procesador. ¡Gracias!
CodeManX
1
Yo diría que si reemplaza el XmlElementcon var, sería mucho más fácil trabajar con el primero
Robert Perry
1
Trabajar con un diccionario -> nivel2 anterior proviene de un diccionario en mi caso (en caso de que alguien lo encuentre útil) Al probar el primer ejemplo, me encontré con este error:
"Este documento ya tiene un nodo 'DocumentElement'".
Me inspiré en la respuesta aquí.
y edité mi código: (xmlDoc. DocumentElement .AppendChild (cuerpo))
//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 versiones (1 y 2 dentro de cada bucle) dan la salida:
(Nota: la tercera línea "mismo nivel2" en el diccionario también puede ser nivel2 como las demás, pero quería ilustrar la ventaja del diccionario; en mi caso, necesitaba nivel2 con nombres diferentes.
Respuestas:
Qué pasa:
#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) ¿Un archivo XML válido requiere una declaración xml?
(2) ¿Cuál es la diferencia entre String.Empty y “” (cadena vacía)?
El resultado es:
<?xml version="1.0" encoding="UTF-8"?> <body> <level1> <level2>text</level2> <level2>other text</level2> </level1> </body>
Pero te recomiendo que uses LINQ to XML, que es más simple y legible como aquí:
#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" ); } }
fuente
XmlElement
convar
, sería mucho más fácil trabajar con el primeroTrabajar con un diccionario -> nivel2 anterior proviene de un diccionario en mi caso (en caso de que alguien lo encuentre útil) Al probar el primer ejemplo, me encontré con este error: "Este documento ya tiene un nodo 'DocumentElement'". Me inspiré en la respuesta aquí.
y edité mi código: (xmlDoc. DocumentElement .AppendChild (cuerpo))
//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 versiones (1 y 2 dentro de cada bucle) dan la salida:
<?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: la tercera línea "mismo nivel2" en el diccionario también puede ser nivel2 como las demás, pero quería ilustrar la ventaja del diccionario; en mi caso, necesitaba nivel2 con nombres diferentes.
fuente