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 :

Modification fichier xml


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Femme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 4
    Par défaut Modification fichier xml
    Bonjour à tous et toutes,

    J'essaye à l'heure actuelle de modifier la 2ème ligne d'un fichier xml généré à partir d'Excel.
    Ligne initiale :
    <all_comments xmlnssi="http://www.w3.org/2001/XMLSchema-instance">
    Ligne attendue:
    <all_comments mode="diff">

    J'arrive bien à :
    - récupérer le contenu du fichier
    - modifier la ligne que je veux en passant par la fonction replace
    - afficher via la fonction MsgBox le nouveau texte
    mais impossible de le remettre dans mon fichier xml pour le sauvegarder. J'ai une erreur sur la ligne de sauvegarde sur le type d'objet

    Est-ce la bonne méthode ?
    J'ai essayé en passant par les noeuds mais je n'y arrive pas.

    Avez-vous des conseils ?

    Voici mon code :
    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
     
    Sub ModifyXMLFile()
    Set xmlDoc = CreateObject("Microsoft.XMLDOM")
    Set XML_Content = CreateObject("Microsoft.XMLDOM")
    xmlDoc.async = False
    If xmlDoc.Load("C:\export_xml_10-08-2017.xml") Then
            'MsgBox "Document XML correctement chargé"
            XML_Content = xmlDoc.XML
            TexteInitial = "<all_reviews xmlns:xsi=""" & "http://www.w3.org/2001/XMLSchema-instance" & """" & ">"
            TexteNouveau = "<all_reviews mode=""" & "diff" & """" & ">"
            XML_Content = Replace(XML_Content, TexteInitial, TexteNouveau)
            xmlDoc = XML_Content
            MsgBox XML_Content
            xmlDoc.Save "C:\export_xml_10-08-2017_modified.xml"
    Else
            MsgBox "Erreur de lecture du document XML"
    End If
     
    Set xmlDoc = Nothing
     
    End Sub

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut.

    Je pense qu'il faut remplacer xmlDoc = XML_Content par xmlDoc.xml = XML_Content à la ligne 12 du code fourni (mais je n'ai pas testé).
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  3. #3
    Membre à l'essai
    Femme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 4
    Par défaut
    Merci de la réponse.
    J'avais déjà essayé mais ça ne lui plait pas.

  4. #4
    Membre à l'essai
    Femme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 4
    Par défaut
    Avec cette ligne, j'ai le message d'erreur :
    Nombre d'arguments incorrect ou affectation de propriété incorrecte

  5. #5
    Membre émérite
    Homme Profil pro
    ingénieur d'étude
    Inscrit en
    Juin 2013
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ingénieur d'étude
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2013
    Messages : 563
    Par défaut
    Bonjour,

    Avez-vous essayer avec la méthode loadXML documentée ici ?

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Oui, j'ai été trop vite

    Remplace la ligne 12 par xmldoc.loadxml content[EDIT] Oups, coiffé par Ben_L
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  7. #7
    Membre à l'essai
    Femme Profil pro
    Consultant MOA
    Inscrit en
    Août 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant MOA

    Informations forums :
    Inscription : Août 2017
    Messages : 4
    Par défaut
    Oui, ça marche beaucoup mieux.
    Merci beaucoup pour cette aide très utile pour me débloquer

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Modification fichier XML
    Par eikeshi dans le forum VB.NET
    Réponses: 11
    Dernier message: 22/12/2008, 14h24
  2. Parsing et modification fichier xml
    Par Premium dans le forum Modules
    Réponses: 2
    Dernier message: 02/12/2008, 15h49
  3. Modification fichier XML
    Par pitch21 dans le forum Windows Forms
    Réponses: 0
    Dernier message: 03/11/2008, 08h39
  4. Modification fichier xml
    Par Jasou62114 dans le forum Web
    Réponses: 6
    Dernier message: 23/01/2008, 15h42
  5. [VB.NET] modification fichier XML
    Par betaphp dans le forum Windows Forms
    Réponses: 5
    Dernier message: 12/11/2005, 11h13

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