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 exploiter les résultats de la boite de dialogue ouverte par Close


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 13
    Par défaut Comment exploiter les résultats de la boite de dialogue ouverte par Close
    Bonjour
    Un bouton lance la tentative de fermeture du classeur : ActiveWorkbook.Close
    Si le classeur a été modifié, une boîte de dialogue s'ouvre
    - Enregistrer ? - Ne Pas enregistrer ? - Abandon
    Comment puis-je récupérer, dans le code du bouton, l'information de ce qui a été choisi ?
    Si ce sont les deux premiers, pas de problème, je sais que le classeur a été fermé, mais dans le cas Abandon, j'ai besoin de savoir, car le classeur est resté ouvert

    Pour l'instant je suppose que l'on n'a pas abandonné ....
    Merci
    Windows 10, Office 2016

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    Si ce sont les deux premiers, pas de problème, je sais que le classeur a été fermé, mais dans le cas Abandon, j'ai besoin de savoir, car le classeur est resté ouvert
    Je me suis une fois posé une drôle de question, à savoir :
    Comment déterminer si je suis sorti de la salle dans laquelle je me trouvais ? Et une réponse s'est spontanément imposée : si je me trouvais encore dans cette salle, c'est que je n'en étais pas sorti --->> et donc --->>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Set toto = ActiveWorkbook
      toto.Close
      If ActiveWorkbook Is toto Then MsgBox "il est toujours là, mon classeur actif"

  3. #3
    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 une autre idée
    heu je me trompe peut etre
    mais la chose est simple
    a suposer que ton bouton soit dans la feuil1!!!!!!!
    dans le thisworkbook tu met

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Workbook_BeforeClose(Cancel As Boolean)
    Feuil1.cancel_After_dialog = Cancel
    End Sub
    dans la Feuil1 ou se trouve l'evenement du bouton

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    [Public cancel_After_dialog 
    Private Sub CommandButton1_Click()
    ActiveWorkbook.Close
     
    MsgBox cancel_After_dialog
    End Sub
    j'ai volontairement non typé la variable pour etre sur

    celat dit comme ceci tu a une variable déterminée en cas d'annulation dans le dialog pour une eventuelle utilisation dans une eventuelle macro ou a la suite du code cet evenement

    et puis de toute facon la macro s'arrete a close si tu n'abandonne pas et le fichier est fermé pour (enregistrer,enregistrer sous ) sans abandon
    donc si tu abandonne tu peux eventuellement coder en dessous la ligne du close qui s'executera tout simplement
    attention tout de meme si le classeur est tout seul dans l'instance l'application reste active et donc doit etre fermée manuellement (double manoeuvre)
    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

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 13
    Par défaut Merci pour ton idée
    Citation Envoyé par patricktoulon Voir le message
    heu je me trompe peut etre
    mais la chose est simple
    a suposer que ton bouton soit dans la feuil1!!!!!!!
    dans le thisworkbook tu met

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Workbook_BeforeClose(Cancel As Boolean)
    Feuil1.cancel_After_dialog = Cancel
    End Sub
    dans la Feuil1 ou se trouve l'evenement du bouton

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    [Public cancel_After_dialog 
    Private Sub CommandButton1_Click()
    ActiveWorkbook.Close
     
    MsgBox cancel_After_dialog
    End Sub
    j'ai volontairement non typé la variable pour etre sur

    celat dit comme ceci tu a une variable déterminée en cas d'annulation dans le dialog pour une eventuelle utilisation dans une eventuelle macro ou a la suite du code cet evenement

    et puis de toute facon la macro s'arrete a close si tu n'abandonne pas et le fichier est fermé pour (enregistrer,enregistrer sous ) sans abandon
    donc si tu abandonne tu peux eventuellement coder en dessous la ligne du close qui s'executera tout simplement
    attention tout de meme si le classeur est tout seul dans l'instance l'application reste active et donc doit etre fermée manuellement (double manoeuvre)
    Elle ne s'applique pas à mon cas, car les classeurs que je manipule sont des classeurs de données, objets traités par mon application; donc je ne peux pas les modifier ...
    Merci quand même

  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
    re
    objets traités par mon application
    quelle application?
    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
    Membre averti
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 13
    Par défaut Quelle application
    Citation Envoyé par patricktoulon Voir le message
    re

    quelle application?
    Bonjour
    J'ai un classeur Excel qui est en réalité une application VBA qui gère des classeurs Excel de données : saisies, conversions, extractions, comparaisons, archivages .....
    Le tout dans un contexte de généalogie .....
    @+

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

Discussions similaires

  1. Comment classer les résultats de ma requete ?
    Par eustache dans le forum Requêtes et SQL.
    Réponses: 19
    Dernier message: 27/02/2009, 22h03
  2. [PLS Toolbox][nippls] Comment exploiter les résultats
    Par yoann_deygas dans le forum MATLAB
    Réponses: 5
    Dernier message: 18/06/2008, 10h03
  3. comment exploiter les codes d'erreurs sous windows xp?
    Par lejum2005 dans le forum Windows XP
    Réponses: 4
    Dernier message: 03/03/2006, 17h26
  4. [SimpleXML] Comment exploiter le résultat d'une requête XML-RPC
    Par tiboel dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 28/02/2006, 19h57
  5. [cr 8.5] comment exploiter les données d'un "array"
    Par kikidrome dans le forum SAP Crystal Reports
    Réponses: 12
    Dernier message: 09/06/2005, 14h03

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