IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

VBA - XML - Accès à un noeud


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 2
    Par défaut VBA - XML - Accès à un noeud
    Bonjour,

    J'ai un fichier XML structuré de la manière suivante :
    Nom : XML_Struct.png
Affichages : 923
Taille : 69,7 Ko

    J'aimerais parvenir à récupérer la valeur "Tarte" du noeud <refobj> entouré en vert.
    Pour y accéder je connais les éléments entourés en rouge.

    Je pensais faire la requête suivante :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For Each Match In Matches.SelectNodes("/project/namespace/namespace/querySubject[name[@locale='en-gb']='Dessert']/queryItem[name[@locale='fr-be']='Patisserie']/expression[name[@locale='en-gb']='Cake']/refobj") 
      MsgBox Match.Text
    Next

    Mais ça ne ramène rien.

    Avez-vous une idée pour parvenir à mes fins ?

    En vous remerciant par avance.

    Cordialement,

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    ton exemple XML me semble parfait, mais même en utilisant Photoshop je n’arrive pas à le parser!

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 2
    Par défaut
    Voici le code au format texte si besoin

    Code xml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    <project>
    	<...>
    	</...>
    	<namespace>
    		<namespace>
    			...
    		</namespace>
    		<namespace>
    			<name locale="fr-be">Dessert</name>
    			<name locale="fr">Dessert</name>
    			<name locale="en-gb">Dessert</name>
    			<...></...>
    			<querySubject>
    				<name locale="fr-be">Patisserie</name>
    				<name locale="fr">Patisserie</name>
    				<name locale="en-gb">Baking</name>
    				<...></...>
    				<queryItem>
    					...
    				</queryItem>
    					...
    				<queryItem>
    					...
    				</queryItem>
    				<queryItem>
    					<name locale="fr-be">Gateau</name>
    					<name locale="fr">Gateau</name>
    					<name locale="en-gb">Cake</name>
    					<...></...>
    					<expression>
    						<refobj>
    							Tarte
    						</refobj>
    					</expression>
    				</queryItem>
    				<queryItem>
    					...
    				</queryItem>
    			</querySubject>
    			<querySubject>
    				...
    			</querySubject>
    			<querySubject>
    				...
    			</querySubject>
    			<querySubject>
    				...
    			</querySubject>
    		</namespace>
    		<namespace>
    			...
    		</namespace>		
    		<namespace>
    			...
    		</namespace>		
    	</namespace>
    </project>

  4. #4
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    Bonjour dans le pire des cas si tu n'arrive pas a jouer avec les nodes avec l'object adob

    tu le fait simplement en string avec split tout simplement façon JSON
    tu split par namespace
    tout tes namespace tu les split par "name local"
    tu prend le 3eme et tu le splt par ">"(1) et "<"(0)
    et tu fait pareil pour l'autre nœud
    rien de bien compliqué
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  5. #5
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    perso j'ai essayé avec ulead photo express mais ca n'a pas marché non plus

    par contre non l'exemple qu'il a fourni en code n'est pas conforme nœud non fermé
    un exemple complet serait le bien venu

    car dans l'exemple il y a plusieurs subject pour le même namespace le quel on prend hein ???????

    ceci: pour moi est un exemple propre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    <project>
     
     <namespaces>
      <namespace>
     
       <name locale="fr-be">Dessert</name>
       <name locale="fr">Dessert</name>
       <name locale="en-gb">Dessert</name>
     
       <querySubject>
        <name locale="fr-be">Patisserie</name>
        <name locale="fr">Patisserie</name>
        <name locale="en-gb">Baking</name>
     
        <queryItem>
         <name locale="fr-be">Gateau</name>
         <name locale="fr">Gateau</name>
         <name locale="en-gb">Cake</name>
     
         <expression>
          <refobj>
           4 quart
          </refobj>
         </expression>
        </queryItem>
     
                      <queryItem>
         <name locale="fr-be">tarte</name>
         <name locale="fr">tarte</name>
         <name locale="en-gb">pie</name>
     
         <expression>
          <refobj>
           fruit pie(fruit tart)
          </refobj>
         </expression>
        </queryItem> 
     
                               </querySubject>                
                   </namespace>  
     
     </namespaces>
    </project>
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  6. #6
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    Sub test()
    Set rs = LoadRsFromXML("C:\MyRepertoire\TestRd2.Xml")
    MsgBox rs("namespace").Value.fields("querySubject").Value.fields("queryItem").Value.fields("expression").Value.fields("refobj").Value
    rs.Close
    End Sub
    Public Function LoadRsFromXML(FullPath As String) As Object 
    '**************************************************
    'PURPOSE: LOAD A RECORDSET FROM AN XML FILE USING
    'ADO 2.5.  THE XML FILE MUST HAVE BEEN SAVED
    'USING SAVE METHOD OF RECORDSET OBJECT WITH adPersistXML AD
    'SECOND PARAMETER
     
    'PARAMETERS:
     'FullPath:     FullPath of XMLFile to load
     
    'RETURNS:       Reference to a Recordset Object, or Nothing if
    '               Function fails
    'REQUIRES:      Installation of and reference to ADO 2.5
    'EXAMPLE:       See Example for SaveRsToXML
     
    '******************************************************
     
    Dim oRs As Object, adoConn As Object
    Set GetXMLDB = CreateObject("ADODB.Connection")
     
    With GetXMLDB
    .Open "Provider=MSDAOSP; Data Source=MSXML2.DSOControl;"
    End With
    Set oRs = CreateObject("ADODB.Recordset")
    On Error Resume Next
    Const adCmdFile = 256
    Const adOpenForwardOnly = 0
    Const adLockReadOnly = 1
    If Dir(FullPath) = "" Then Exit Function
    oRs.Open FullPath, GetXMLDB
     
    If Err.Number = 0 Then
        Set LoadRsFromXML = oRs
    End If
     
    End Function

Discussions similaires

  1. Accès aux noeuds d'un document XML
    Par Ashitaka dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 07/08/2007, 15h15
  2. XML insertion de noeud
    Par totoche dans le forum ASP
    Réponses: 2
    Dernier message: 27/09/2005, 10h57
  3. asp xml extraction de noeuds
    Par totoche dans le forum ASP
    Réponses: 2
    Dernier message: 31/08/2005, 15h24
  4. [C#] [XML] Insérer un noeud entre un parent et ses enfants
    Par frechy dans le forum Windows Forms
    Réponses: 10
    Dernier message: 04/04/2005, 15h52
  5. [VB.NET] XML - Trier des noeuds
    Par nako dans le forum VB.NET
    Réponses: 2
    Dernier message: 10/06/2004, 09h13

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo