Autres Mapper fichier XML dans Excel avec TLE

FS69

XLDnaute Nouveau
Bonjour,

Je suis un novice en XML et Excel aussi, je dois constituer un fichier csv basé sur un XML afin de faire correspondre les données du XML dans la colonne/position attendue.

Le fichier XML contient des "name" et des "value". chaque "name" à une "value" associée et séparé par un "TLE"

Comment puis je faire pour que chaque "name" puisse être identifiée comme une zone de mappage et qu'ainsi les "value" soient positionnées

1722870633485.png

1722871148470.png
 
Solution
re
c'est pas une ligne qu'il faut changer
on garde le moteur on met un carbu double corps on remplace les cable par l'hydrolique
on modifie un peu ici et là
on la transform en fonction
on ajoute une sub de pilotage (grand guidon)
:D
choisi le dossier dans la boite de dialogue
VB:
Sub test()
    Dim sfolder$, fichier, header$, y&, file$
    fichier = ThisWorkbook.Path & "\compilation.csv"
    With Application.FileDialog(msoFileDialogFolderPicker)
        If .Show = -1 Then ' if OK is pressed
            sfolder = .SelectedItems(1)
            Else: Exit Sub
        End If
    End With
    header = "NumeroCient;NumeroContrat;NumeroSinistre;Identifiant Unique document;Code Maquette;Date de creation Document;Civilité;Nom;Prenom;" & _...

patricktoulon

XLDnaute Barbatruc
re
ceci devrait faire l'affaire
j'ai ajouté la boite de dialog selection de fichier vous n'aurez pas a changer dans le code comme ça
on pourrait aussi adapter avec un dossier et lui faire faire tout les xml a la suite en un coup
VB:
Sub test()
    Dim T, NodeDoc, Nodexs As Object, x&, header, tabhead, tb$(), i, myfile$, myfileCsV$
    header = "NumeroCient;NumeroContrat;NumeroSinistre;Identifiant Unique document;Code Maquette;Date de creation Document;Civilité;Nom;Prenom;" & _
              "branche;famille;Sous famille;Sous Famille2;Libellé Produit;Univers;sendflux;sourceged;libelléstatut;docencrys;" & _
              "IDAQUISIT;IDAQUISIT;IDAQUISIT;Chemin d'acces au fichier"
    tabhead = Split(header, ";")

    myfile = Application.GetOpenFilename("XML Files (*.xml), *.xml", 1, "ouvrir un fichier xml")
     If myfile = "Faux" Then Exit Sub

    myfileCsV = Replace(myfile, ".xml", ".csv")

    With CreateObject("microsoft.xmldom")
        .Load myfile
        Set NodeDoc = .getelementsbytagname("Document")
        For i = 0 To NodeDoc.Length - 1
            ReDim tb(UBound(tabhead)) ' t = t & Nodexs(i).Text & ":" & vbTab & Nodexs(i).NextSibling.Text & vbCrLf
            tb(UBound(tb)) = NodeDoc(i).ChildNodes(0).Text

            Set Nodexs = NodeDoc(i).getelementsbytagname("Name")
            For a = 0 To Nodexs.Length - 1
                Select Case Nodexs(a).Text
                    Case "datedoc": tb(5) = Nodexs(a).NextSibling.Text
                    Case "numadh": tb(1) = Nodexs(a).NextSibling.Text
                    Case "numcli": tb(0) = Nodexs(a).NextSibling.Text
                    Case "cciv": tb(6) = Nodexs(a).NextSibling.Text
                    Case "nom1": tb(8) = Nodexs(a).NextSibling.Text
                    Case "nom2": tb(7) = Nodexs(a).NextSibling.Text
                    Case "cetat": tb(4) = Nodexs(a).NextSibling.Text
                End Select

            Next
            T = T & Join(tb, ";") & vbCrLf
        Next
    End With
    T = header & vbCrLf & T
    x = FreeFile: Open myfileCsV For Output As #x: Print #x, T: Close #x
    MsgBox "votre fichier xml a été converti"
End Sub
testé avec ton dernier fichier xml de ton archive
 

patricktoulon

XLDnaute Barbatruc
re
normalement si le xml avait été bien fait ou mieux fait ça aurait été
Code:
 Case "datedoc": tb(5) = Nodexs(a).ChildNodes(0).text
                    Case "numadh": tb(1) = Nodexs(a).ChildNodes(0).text
                    Case "numcli": tb(0) = Nodexs(a).ChildNodes(0).text
                    Case "cciv": tb(6) = Nodexs(a).ChildNodes(0).text
                    Case "nom1": tb(8) = Nodexs(a).ChildNodes(0).text
                    Case "nom2": tb(7) = Nodexs(a).ChildNodes(0).text
                    Case "cetat": tb(4) = Nodexs(a).ChildNodes(0).text
 

FS69

XLDnaute Nouveau
re
ceci devrait faire l'affaire
j'ai ajouté la boite de dialog selection de fichier vous n'aurez pas a changer dans le code comme ça
on pourrait aussi adapter avec un dossier et lui faire faire tout les xml a la suite en un coup
VB:
Sub test()
    Dim T, NodeDoc, Nodexs As Object, x&, header, tabhead, tb$(), i, myfile$, myfileCsV$
    header = "NumeroCient;NumeroContrat;NumeroSinistre;Identifiant Unique document;Code Maquette;Date de creation Document;Civilité;Nom;Prenom;" & _
              "branche;famille;Sous famille;Sous Famille2;Libellé Produit;Univers;sendflux;sourceged;libelléstatut;docencrys;" & _
              "IDAQUISIT;IDAQUISIT;IDAQUISIT;Chemin d'acces au fichier"
    tabhead = Split(header, ";")

    myfile = Application.GetOpenFilename("XML Files (*.xml), *.xml", 1, "ouvrir un fichier xml")
     If myfile = "Faux" Then Exit Sub

    myfileCsV = Replace(myfile, ".xml", ".csv")

    With CreateObject("microsoft.xmldom")
        .Load myfile
        Set NodeDoc = .getelementsbytagname("Document")
        For i = 0 To NodeDoc.Length - 1
            ReDim tb(UBound(tabhead)) ' t = t & Nodexs(i).Text & ":" & vbTab & Nodexs(i).NextSibling.Text & vbCrLf
            tb(UBound(tb)) = NodeDoc(i).ChildNodes(0).Text

            Set Nodexs = NodeDoc(i).getelementsbytagname("Name")
            For a = 0 To Nodexs.Length - 1
                Select Case Nodexs(a).Text
                    Case "datedoc": tb(5) = Nodexs(a).NextSibling.Text
                    Case "numadh": tb(1) = Nodexs(a).NextSibling.Text
                    Case "numcli": tb(0) = Nodexs(a).NextSibling.Text
                    Case "cciv": tb(6) = Nodexs(a).NextSibling.Text
                    Case "nom1": tb(8) = Nodexs(a).NextSibling.Text
                    Case "nom2": tb(7) = Nodexs(a).NextSibling.Text
                    Case "cetat": tb(4) = Nodexs(a).NextSibling.Text
                End Select

            Next
            T = T & Join(tb, ";") & vbCrLf
        Next
    End With
    T = header & vbCrLf & T
    x = FreeFile: Open myfileCsV For Output As #x: Print #x, T: Close #x
    MsgBox "votre fichier xml a été converti"
End Sub
testé avec ton dernier fichier xml de ton archive
Un seul mot : MERCI !

Si j'abuse un peu (beaucoup) est ce possible d'avoir la ligne de commande pour ouvrir les XML présents dans un dossier et un seul csv ?

Si vous ne pouvez pas aucun soucis vous m'avez déjà énormément aidé !
 

patricktoulon

XLDnaute Barbatruc
re
c'est pas une ligne qu'il faut changer
on garde le moteur on met un carbu double corps on remplace les cable par l'hydrolique
on modifie un peu ici et là
on la transform en fonction
on ajoute une sub de pilotage (grand guidon)
:D
choisi le dossier dans la boite de dialogue
VB:
Sub test()
    Dim sfolder$, fichier, header$, y&, file$
    fichier = ThisWorkbook.Path & "\compilation.csv"
    With Application.FileDialog(msoFileDialogFolderPicker)
        If .Show = -1 Then ' if OK is pressed
            sfolder = .SelectedItems(1)
            Else: Exit Sub
        End If
    End With
    header = "NumeroCient;NumeroContrat;NumeroSinistre;Identifiant Unique document;Code Maquette;Date de creation Document;Civilité;Nom;Prenom;" & _
              "branche;famille;Sous famille;Sous Famille2;Libellé Produit;Univers;sendflux;sourceged;libelléstatut;docencrys;" & _
              "IDAQUISIT;IDAQUISIT;IDAQUISIT;Chemin d'acces au fichier"
    y = FreeFile: Open fichier For Output As #y: Print #y, header: Close #y
    NbCol = UBound(Split(header, ";"))

    file = Dir(sfolder & "\*.xml")
    Do While file <> ""
        ok = mangetout(sfolder & "\" & file, fichier, NbCol)
       ' MsgBox file
        Do While a = 500: DoEvents: a = a + 1: Loop
        DoEvents
        file = Dir()
    Loop
    MsgBox "votre compilation en csv est prête "


End Sub

Function mangetout(myfile, compilcsv, NbCol)
    Dim T, NodeDoc, Nodexs As Object, x&, header, tabhead, tb$(), i

    With CreateObject("microsoft.xmldom")
        .Load myfile
        Set NodeDoc = .getelementsbytagname("Document")
        For i = 0 To NodeDoc.Length - 1
            ReDim tb(NbCol) ' t = t & Nodexs(i).Text & ":" & vbTab & Nodexs(i).NextSibling.Text & vbCrLf
            tb(UBound(tb)) = NodeDoc(i).ChildNodes(0).Text

            Set Nodexs = NodeDoc(i).getelementsbytagname("Name")
            For a = 0 To Nodexs.Length - 1
                Select Case Nodexs(a).Text
                    Case "datedoc": tb(5) = Nodexs(a).NextSibling.Text
                    Case "numadh": tb(1) = Nodexs(a).NextSibling.Text
                    Case "numcli": tb(0) = Nodexs(a).NextSibling.Text
                    Case "cciv": tb(6) = Nodexs(a).NextSibling.Text
                    Case "nom1": tb(8) = Nodexs(a).NextSibling.Text
                    Case "nom2": tb(7) = Nodexs(a).NextSibling.Text
                    Case "cetat": tb(4) = Nodexs(a).NextSibling.Text
                End Select

            Next
            T = T & Join(tb, ";") & IIf(i < NodeDoc.Length - 1, vbCrLf, "")
        Next
    End With
    x = FreeFile: Open compilcsv For Append As #x: Print #x, T: Close #x
    mangetout = True
End Function
maintenant tu peux cocher résolu a droite de ce message;)
 
Dernière édition:

FS69

XLDnaute Nouveau
re
c'est pas une ligne qu'il faut changer
on garde le moteur on met un carbu double corps on remplace les cable par l'hydrolique
on modifie un peu ici et là
on la transform en fonction
on ajoute une sub de pilotage (grand guidon)
:D
choisi le dossier dans la boite de dialogue
VB:
Sub test()
    Dim sfolder$, fichier, header$, y&, file$
    fichier = ThisWorkbook.Path & "\compilation.csv"
    With Application.FileDialog(msoFileDialogFolderPicker)
        If .Show = -1 Then ' if OK is pressed
            sfolder = .SelectedItems(1)
            Else: Exit Sub
        End If
    End With
    header = "NumeroCient;NumeroContrat;NumeroSinistre;Identifiant Unique document;Code Maquette;Date de creation Document;Civilité;Nom;Prenom;" & _
              "branche;famille;Sous famille;Sous Famille2;Libellé Produit;Univers;sendflux;sourceged;libelléstatut;docencrys;" & _
              "IDAQUISIT;IDAQUISIT;IDAQUISIT;Chemin d'acces au fichier"
    y = FreeFile: Open fichier For Output As #y: Print #y, header: Close #y
    NbCol = UBound(Split(header, ";"))

    file = Dir(sfolder & "\*.xml")
    Do While file <> ""
        ok = mangetout(sfolder & "\" & file, fichier, NbCol)
       ' MsgBox file
        Do While a = 500: DoEvents: a = a + 1: Loop
        DoEvents
        file = Dir()
    Loop
    MsgBox "votre compilation en csv est prête "


End Sub

Function mangetout(myfile, compilcsv, NbCol)
    Dim T, NodeDoc, Nodexs As Object, x&, header, tabhead, tb$(), i

    With CreateObject("microsoft.xmldom")
        .Load myfile
        Set NodeDoc = .getelementsbytagname("Document")
        For i = 0 To NodeDoc.Length - 1
            ReDim tb(NbCol) ' t = t & Nodexs(i).Text & ":" & vbTab & Nodexs(i).NextSibling.Text & vbCrLf
            tb(UBound(tb)) = NodeDoc(i).ChildNodes(0).Text

            Set Nodexs = NodeDoc(i).getelementsbytagname("Name")
            For a = 0 To Nodexs.Length - 1
                Select Case Nodexs(a).Text
                    Case "datedoc": tb(5) = Nodexs(a).NextSibling.Text
                    Case "numadh": tb(1) = Nodexs(a).NextSibling.Text
                    Case "numcli": tb(0) = Nodexs(a).NextSibling.Text
                    Case "cciv": tb(6) = Nodexs(a).NextSibling.Text
                    Case "nom1": tb(8) = Nodexs(a).NextSibling.Text
                    Case "nom2": tb(7) = Nodexs(a).NextSibling.Text
                    Case "cetat": tb(4) = Nodexs(a).NextSibling.Text
                End Select

            Next
            T = T & Join(tb, ";") & IIf(i < NodeDoc.Length - 1, vbCrLf, "")
        Next
    End With
    x = FreeFile: Open compilcsv For Append As #x: Print #x, T: Close #x
    mangetout = True
End Function
maintenant tu peux cocher résolu a droite de ce message;)
Effectivement ce n'était pas aussi simple... :)

Merci pour votre travail et le temps que vous avez pu y consacrer, je vous remercie vivement !
 

Discussions similaires

Réponses
10
Affichages
403

Statistiques des forums

Discussions
315 088
Messages
2 116 088
Membres
112 656
dernier inscrit
VNVT