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 :

Comment m'en débarrasser ?


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé Avatar de touche_a_tout
    Profil pro
    Inscrit en
    Août 2006
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2006
    Messages : 533
    Par défaut Comment m'en débarrasser ?
    Bonjour toutes et tous,
    J'ai une bidouille qui a eu marché mais maintenant elle s'exécute sans fin. Voici l'extrait du code concerné:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
         'Créer une instance de Word
        Set appWord = GetObject("Word.Application") ' Vérifie si Word est déjà ouvert
        If appWord Is Nothing Then
            Set appWord = CreateObject("Word.Application") ' Sinon, ouvrir une nouvelle instance
            'Fermer_Word = " True"
        End If
        On Error GoTo 0
     
    Set WordDoc1 = appWord.Documents.Open("E:\2_M_E_S__P_R_O_J_E_T_S\Périple\5ème analyse\analyse_epil_A.docm")
    A la première exécution tout s'est bien passé. A partir de la deuxième exécution le code mouline sans fin sur la dernière ligne et je dois faire Ctrl/Alt + Del pour le stopper. Je trouve alors le message "Le fichier word analyse_epil_A.docm est en cours d'utilisation par (moi)". J'ai redémarré pour vider la mémoire mais sans résultat. J'ai enlevé l'apostrophe à la ligne 5 (Fermer Word = True") mais ça ne change rien. Comment me débarrasser de ce fichier Word ? Ajouter quelque part - mais où ? - une ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    analyse_epil_A.docm = Nothing
    ?
    Merci d'avance pour toute piste.
    Cordialement
    touche_a_tout

  2. #2
    Membre confirmé
    Homme Profil pro
    curieux
    Inscrit en
    Février 2025
    Messages
    26
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Italie

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

    Informations forums :
    Inscription : Février 2025
    Messages : 26
    Par défaut
    Bonjour,

    Il faut (sauvegarder) et fermer votre fichier avant de supprimer son pointeur. Essentiellement votre code "Set monDocument = Nothing" veut dire à l'ordinateur d'oublier qu'il a ouvert le document… D'où votre problème d'accessibilité lors du second run.

    Ecrivez donc d'abord
    Pour le fermer correctement, avant de "l'oublier".

  3. #3
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 050
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 050
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    En complément de fermer le document comme proposé par sabot'age, il faudrait peut-être quitter word
    du type
    appword.quit
    :bug:

  4. #4
    Membre éclairé Avatar de touche_a_tout
    Profil pro
    Inscrit en
    Août 2006
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2006
    Messages : 533
    Par défaut [XL-2016] Comment m'en débarrasser ?
    Merci sabot'age et tototiti,
    Je vais tester vos deux propositions et donner des nouvelles
    Cordialement
    touche_a_tout

  5. #5
    Membre éclairé Avatar de touche_a_tout
    Profil pro
    Inscrit en
    Août 2006
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2006
    Messages : 533
    Par défaut [XL-2016] Comment m'en débarrasser ? Votre message
    Rebonjour,
    Hélas il y a un souci.
    L'erreur se produit à la ligne 9, il faut donc, pour éviter l'erreur, que mondocument soit fermé avant, mais alors la ligne 9 ne fonctionne plus si mondocument est fermé. Même chose si on quitte appWord avant la ligne 9.
    Et si on met l'une ou l'autre de ces instructions après la ligne 9, c'est trop tard, l'erreur a eu lieu.
    Ou alors est-ce que je n'ai rien compris ?
    Merci à qui pourra me dépanner.
    Cordialement
    touche_a_tout

  6. #6
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 050
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 050
    Billets dans le blog
    2
    Par défaut
    Re,

    Si j'ai bien compris, il faut lancer le gestionnaire de tâches et tuer tous les processus Word (sauvegarder avant si besoin)
    puis mettre le code de sabot'age (et le mien si on veut quitter Word) après la ligne 9 (à la fin de la macro, une fois les traitements Word terminés)
    puis lancer tout ça plusieurs fois pour voir si le problème persiste
    :bug:

  7. #7
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 050
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 050
    Billets dans le blog
    2
    Par défaut
    Re,
    Ce qui devrait donner en fin de macro, étant donné le nom des variables

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    WordDoc1.Save 'si on veut enregistrer les modifications
    WordDoc1.Close
    AppWord.Quit 'si on veut quitter Word
    Set WordDoc1 = Nothing
    Set AppWord = Nothing
    et non pas (il n'y a pas de variable de ce nom)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    analyse_epil_A.docm = Nothing
    :bug:

  8. #8
    Membre éclairé Avatar de touche_a_tout
    Profil pro
    Inscrit en
    Août 2006
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2006
    Messages : 533
    Par défaut [XL-2016] Comment m'en débarrasser ?
    Bien reçu et merci, tototiti.
    Je m'y remets au plus tôt demain.
    Cordialement
    touche_a_tout

  9. #9
    Membre éclairé Avatar de touche_a_tout
    Profil pro
    Inscrit en
    Août 2006
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2006
    Messages : 533
    Par défaut [XL-2016] Comment m'en débarrasser ?
    Bonjour,
    J'ai un peu tardé parce que, pour tout dire, mon texte faisait 55000 lignes environ et ça prenait tellement de temps que j'ai voulu le traiter en quatre fois avec une variable tableau WordDoc(1 to 4); mais ça me compliquait tellement l'existence que je suis revenu à la version du traitement en une fois et grâce à votre aide, ça marche ! Une fois le texte réparti à raison d'un mot par cellule j'ai une moulinette qui calcule la fréquence de chaque mot et la proportion de mots utilisés une seule fois par rapport au total des mots utilisés est un indicateur de la richesse du vocabulaire. Donc grand merci à vous deux !
    Cordialement
    touche_a_tout

Discussions similaires

  1. Réponses: 5
    Dernier message: 20/08/2002, 19h01
  2. [langage] comment créer des fichiers ?
    Par Anonymous dans le forum Langage
    Réponses: 3
    Dernier message: 05/05/2002, 17h33
  3. Réponses: 7
    Dernier message: 01/05/2002, 21h23
  4. Comment faire pour créer un bitmap
    Par GliGli dans le forum C++Builder
    Réponses: 2
    Dernier message: 24/04/2002, 16h41
  5. Comment débuter en programmation ?
    Par Marc Lussac dans le forum Débuter
    Réponses: 0
    Dernier message: 08/04/2002, 12h29

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