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 :

Utilisation de enableevents [XL-365]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2017
    Messages
    1 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Juillet 2017
    Messages : 1 291
    Par défaut Utilisation de enableevents
    Bonjour,

    tout d'abord voici le code objet de ma question
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Private Sub Workbook_BeforeClose(Cancel As Boolean)
    ...
    Application.EnableEvents = False
    ActiveWorkbook.Close savechanges:=False
    Application.EnableEvents = True
    Je veux donc autofermer mon classeur en cours SANS INVITE mais sans réexécuter "Workbook_BeforeClose" en passant sur "ActiveWorkbook.Close"

    Tout se passe bien sauf que bien sur que "Application.EnableEvents = True" ne s'exécute pas puisque le classeur est fermé...

    Du coup les événements sont désactivés pour le reste de la session et ça ne va pas.

    Je pense que mon code n'est pas optimum, on doit pouvoir faire sans recoder un "ActiveWorkbook.Close"

  2. #2
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 196
    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 196
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Je crois qu'il y a incompréhension

    s'éxécute quand on a déjà demandé de fermer le classeur, il est donc inutile de demander de fermer le classeur avec un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveWorkbook.Close savechanges:=False
    le classeur va se fermer de toute façon

    Si on veut éviter la question sur l'enregistrement, soit au moment de fermer le classeur programmatiquement on précise qu'on n'enregistre pas

    Soit si c'est une demande de fermeture manuelle de l'utilisateur de fermer le classeur, on précise qu'il faut agir comme si le classeur était déjà enregistré
    dans ce cas un truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Workbook_BeforeClose(Cancel As Boolean)
        ThisWorkbook.Saved = True
    End Sub
    Devrait le faire

    Edit :
    Préferer Thisworkbook à Activeworkbook, le classeur actif n'est pas forcément le classeur contenant le code

    si on peut éviter l'utilisation des désactivation d'évènements, c'est mieux, c'est toujours un peu dangereux à manipuler

  3. #3
    Membre éprouvé
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2017
    Messages
    1 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Juillet 2017
    Messages : 1 291
    Par défaut
    J'ai testé mais cela ne convient pas complétement

    En fait lorsque l'utilisateur clique sur la croix de fermeture en haut à droite de son écran je veux :

    1) exécuter du code présent dans le code "Workbook_BeforeClose"

    2) ensuite que le classeur se ferme sans enregistrer et surtout sans rien demander à l'utilisateur

    c'est le point 2 qui me pose un problème

  4. #4
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 196
    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 196
    Billets dans le blog
    2
    Par défaut
    Re,

    En fait lorsque l'utilisateur clique sur la croix de fermeture en haut à droite de son écran je veux :

    1) exécuter du code présent dans le code "Workbook_BeforeClose"
    Oui tu peux rajouter ton code au-dessus de la ligne Thisworkbool.Saved=True

    2) ensuite que le classeur se ferme sans enregistrer et surtout sans rien demander à l'utilisateur
    C'est ce qu'est censé faire la ligne Thisworkbool.Saved=True

  5. #5
    Membre éprouvé
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2017
    Messages
    1 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Juillet 2017
    Messages : 1 291
    Par défaut
    Merci, effectivement ça marche bien

    Ce qui m'a induit en erreur c'est "ThisWorkbook.Saved=True"

    "Save = True" dans ma logique cela enregistre le fichier... et bien non...

  6. #6
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 196
    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 196
    Billets dans le blog
    2
    Par défaut
    Re,

    Non, ce qui enregistre c'est Thisworkbook.Save
    Thisworkbook.Saved=True veut dire fait comme si le classeur était enregistré, bien qu'il ne le soit pas
    (il ne faut plus le modifier après, sinon la demande d'enregistrement réapparait)

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

Discussions similaires

  1. utiliser les tag [MFC] [Win32] [.NET] [C++/CLI]
    Par hiko-seijuro dans le forum Visual C++
    Réponses: 8
    Dernier message: 08/06/2005, 15h57
  2. Réponses: 5
    Dernier message: 11/06/2002, 15h21
  3. Réponses: 4
    Dernier message: 05/06/2002, 14h35
  4. utilisation du meta type ANY
    Par Anonymous dans le forum CORBA
    Réponses: 1
    Dernier message: 15/04/2002, 12h36
  5. [BCB5] Utilisation des Ressources (.res)
    Par Vince78 dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/04/2002, 16h01

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