Lo que intento hacer es crear un archivo XML analizando un archivo XLS. Un ejemplo debería ser más relevante:Creación de un archivo XML a partir de celdas XLS mediante indentaciones
| tag1 | | | |
| | tag2 | | |
| | | tag3 | tag3Value |
| | | tag4 | tag4Value |
| | tag5 | | |
| | | tag6 | tag6Value |
| | | | |
Si imaginamos que esas son las células, será equivalente para el siguiente código .xml.
<tag1>
<tag2>
<tag3> tag3Value </tag3>
<tag4> tag4Value </tag4>
</tag2>
<tag5>
<tag6> tag6Value </tag6>
</tag5>
</tag1>
Eso no sería tan duro mediante la gestión de una célula a la vez y sólo haciendo "<" & celular (x, y) & ">" pero quería una solución elegante. Aquí está mi aplicación hasta el momento:
Sub lol()
Sheet1.Activate
Dim xmlDoc As MSXML2.DOMDocument
Dim xmlNode As MSXML2.IXMLDOMNode
Set xmlDoc = New MSXML2.DOMDocument
createXML xmlDoc
End Sub
Sub createXML(xmlDoc As MSXML2.DOMDocument)
Dim newNode As MSXML2.IXMLDOMNode
If Not (Cells(1, 1) = "") Then
'newNode.nodeName = Cells(1, 1)
ReplaceNodeName xmlDoc, newNode, Cells(1, 1)
createXMLpart2 xmlDoc, newNode, 2, 2
xmlDoc.appendChild newNode
End If
xmlDoc.Save "E:\saved_cdCatalog.xml"
End Sub
Sub createXMLpart2(xmlDoc As MSXML2.DOMDocument, node As MSXML2.IXMLDOMElement, i As Integer, j As Integer)
Dim newNode As MSXML2.IXMLDOMElement
If Not (Cells(i, j) = "") Then
If (Cells(i, j + 1) = "") Then
'newNode.nodeName = Cells(i, j)
ReplaceNodeName xmlDoc, newNode, Cells(i, j)
createXMLpart2 xmlDoc, newNode, i + 1, j + 1
Else
'newNode.nodeName = "#text"
ReplaceNodeName xmlDoc, newNode, "#text"
'newNode.nodeValue = Cells(i, j + 1)
createXMLpart2 xmlDoc, newNode, i + 1, j
End If
node.appendChild (newNode)
End If
End Sub
Private Sub ReplaceNodeName(oDoc As DOMDocument, oElement As IXMLDOMElement, newName As String)
Dim ohElement As IXMLDOMElement
Dim sElement As IXMLDOMElement
Dim oChild As IXMLDOMNode
' search the children '
If Not oElement Is Nothing Then
Set ohElement = oElement.parentNode
Set sElement = oDoc.createElement(newName)
For Each oChild In oElement.childNodes
Call sElement.appendChild(oChild)
Next
Call ohElement.replaceChild(sElement, oElement)
End If
End Sub
problemas: en un primer momento no me di cuenta de que no puedo cambiar el nombre de un nodo haciendo node.nodeName = "nuevoNombre" Me han encontrado una solución en StackOverflow actualmente: Change NodeName of an XML tag element using MSXML
Así que he comentado mis intentos de cambiar el nombre de los nodos y probé la versión con el método ReplaceNodeName.
El problema real: node.appendChild (newNode) de createXMLpart2 me da un problema: se supone que la variable "newNode" no está configurada. Estoy desconcertado.
Tuve un problema similar y todavía no he encontrado la respuesta :( –
No soy un experto en VBA, pero al mirar tu código, no entiendo por qué piensas que 'newNode' * would * se inicializó Al comienzo de createXMLpart2(), lo declaras como 'Dim newNode As MSXML2.IXMLDOMElement', pero ¿dónde lo inicializas? – LarsH
¿Por qué quieres reemplazar el nombre del nodo? Deberías crear una instancia de un nuevo objeto nodo para cada nodo en tu XML. – elsni