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 :

Workbook_Open ne s'exécute pas


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 12
    Par défaut Workbook_Open ne s'exécute pas
    Bonjour,
    Quand le tableau incriminé est fermé alors qu'une feuille bien précise est active, la procédure WorkBook_Open ne s'exécute pas quand le classeur est réouvert. Le problème disparait quand le classeur est fermé avec n'importe quelle autre de ses feuilles active.
    D'autre part, si on lance manuellement la macro qui est lancée par le Workbook_Open, elle s'exécute normalement.
    D'avance merci pour une direction dans laquelle chercher.

  2. #2
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonsoir.

    Cela n'est pas vraiment clair, mais je pense que la première chose à faire est de s'assurer si la procédure open s'exécute ou pas.
    Pour cela, tu peux mettre un drapeau en tout début de procédure
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    msgbox "proc workbook_open"
    On verra ensuite.

    PGZ

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 12
    Par défaut
    Merci PGZ de t'intéresser à mon problème. Quand je dis que Workbook_Open ne s'exécute pas, j'ai fait un minimum de vérifications.
    J'ai connu des systèmes qui permettaient d'entrer dans le Debug dès le lancement du programme à tracer, mais je ne sais pas si c'est possible avec VBA.
    Une recherche sur le web montre que je ne suis pas le seul à avoir rencontré un problème avec Workbook_Open, et pas tous à cause du fait qu'ils avaient oublié de mettre la procédure dans Thisworkbook.
    A suivre...

    J'ai essayé d'isoler le problème en réduisant progressivement le contenu de la feuille à l'origine du problème.
    Il semble que l'élément perturbateur soit la présence d'une règle de mise en forme conditionnelle. Il y a 2 règles dans cette feuille, mais seule l'une d'elles provoque le problème. Qu'a donc de particulier cette règle? Elle utilise une "user defined function", qui, par ailleurs, ne pose pas de problèmes.
    Y a-t-il un problème connu quand on utilise une telle fonction dans une règle de mise en forme conditionnelle?

  4. #4
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonjour
    Citation Envoyé par zampano Voir le message
    Merci PGZ de t'intéresser à mon problème. Quand je dis que Workbook_Open ne s'exécute pas, j'ai fait un minimum de vérifications.
    J'ai connu des systèmes qui permettaient d'entrer dans le Debug dès le lancement du programme à tracer, mais je ne sais pas si c'est possible avec VBA.
    Une recherche sur le web montre que je ne suis pas le seul à avoir rencontré un problème avec Workbook_Open, et pas tous à cause du fait qu'ils avaient oublié de mettre la procédure dans Thisworkbook.
    A suivre...
    Tu ne réponds pas vraiment à la question.
    A mon avis, si la prod=cédure évènementielle ne s'exécute pas cela peut être:
    1. Il n'y as pas de procédure correctement orthographiée et correctement placée (cela ne devrait pas être le cas ici, puisque en général elle s'exécute)
    2. L'application a ses procédures évènementielles interdites (Application.EnableEvents). Tu peux ouvrir un classeur vierge, faire
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      Application.EnableEvents = True
      et ouvrir alors le classeur en question.
    3. Il y a une erreur de compilation ou d'exécution. Vérifier que est placé en tête de tous les modules et faire une compilation du code.
    4. La procédure est déclenchée, mais comme elle ne fait pas ce que tu attends, tu crois qu'elle ne s'est pas exécutée. D'où ma proposition de drapeau que tu n'as pas essayée.

    Cordialement,

    PGZ

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 12
    Par défaut
    Excuse moi PGZ, j'aurais dû être plus explicite: la technique du drapeau fait partie des premières vérifications que j'applique.
    D'autre part, j'utilise "Option Explicit" systématiquement.
    Comme j'indique dans mon message de 14h33, je pense avoir cerné la cause du problème, sans pouvoir trouver d'explication pour le moment. Je vais essayer de faire un classeur "minimal" permettant de reproduire le phénomène.

  6. #6
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Re,

    Citation Envoyé par zampano Voir le message
    Je vais essayer de faire un classeur "minimal" permettant de reproduire le phénomène.
    Excel lente idée!

    PGZ

Discussions similaires

  1. [Access] Update ne s'exécute pas complètement car PK
    Par JulienCEA dans le forum Langage SQL
    Réponses: 5
    Dernier message: 21/02/2006, 22h14
  2. Réponses: 13
    Dernier message: 30/01/2006, 14h21
  3. mon programe asp ne s'exécute pas????????????
    Par ghita269 dans le forum ASP
    Réponses: 1
    Dernier message: 07/11/2005, 11h23
  4. jar Eclipse/bureau -> exécute pas mes requetes !!!
    Par Elea49 dans le forum Eclipse Java
    Réponses: 5
    Dernier message: 04/08/2005, 15h11
  5. Réponses: 3
    Dernier message: 09/10/2002, 11h35

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