Yapmaya çalıştığım şey bir XLS dosyasını ayrıştırarak bir XML dosyası oluşturmaktır. Bir örnek daha alakalı olmalıdır:Girintiler yoluyla XLS Hücreleri'nden XML dosyası oluşturma
| tag1 | | | |
| | tag2 | | |
| | | tag3 | tag3Value |
| | | tag4 | tag4Value |
| | tag5 | | |
| | | tag6 | tag6Value |
| | | | |
biz bu hücrelerdir hayal, aşağıdaki .xml kodu için eşdeğer olacaktır. her seferinde bir hücreyi yönetmek ve sadece "<" & Hücre (x, y) & ">" yaparak bu kadar zor olmazdı
<tag1>
<tag2>
<tag3> tag3Value </tag3>
<tag4> tag4Value </tag4>
</tag2>
<tag5>
<tag6> tag6Value </tag6>
</tag5>
</tag1>
Ama zarif bir çözüm istedi.
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
Sorunlar: Ben node.nodeName = "NewName" yaparak bir düğümün adını değiştiremezsiniz fark etmemişti ilk başta bir çözüm bulduk İşte şimdiye kadar benim uygulamasıdır StackOverflow aslında: Change NodeName of an XML tag element using MSXML
Bu yüzden düğümlerimi yeniden adlandırma girişimlerimi yorumladım ve sürümü ReplaceNodeName yöntemiyle denedim.
Asıl sorun: createXMLpart2 öğesinden node.appendChild (newNode) bana bir sorun veriyor: "newNode" değişkeni ayarlanmamış. Şaşkınım.
Benzer bir sorunla karşılaştım ve henüz cevabı bulamadım :( –
VBA'da uzman değilim, ancak kodunuza bakarak neden "newNode" * ın * başlatılacağını düşündüğünüzü anlamıyorum CreateXMLpart2() 'nin başlangıcında,' Dim newNode Olarak MSXML2.IXMLDOMElement 'olarak bildirirsiniz, ancak bunu nereden başlatabilirsiniz? – LarsH
Düğüm adını neden değiştirmek istiyorsunuz? Her düğüm için yeni bir düğüm nesnesi oluşturmalısınız. XML'inizde – elsni