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 :

Désactiver des warnings sous Excel


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut Désactiver des warnings sous Excel
    Bonjour,

    j'ai crée un code depuis Excel qui en gros :

    -appelle et fait tourner des requêtes et d'autres macros sur une BDD Access,
    -rapatrie les données sur Excel et les met en formes
    -enregistre le tout sous format xls nommé avec la date du jour.

    Tout marche bien, mais je suis embêté sur 2 points sous Excel :

    1 / lorsque les requêtes et macros ACCESS tournent, j'ai un warning qui me "harcèle" en disant que "Excel attend qu' une autre application finisse une action OLE"

    2/ Tout à la fin, lors de l'enregistrement du nouveau doc Excel, un message me dit que "ce classeur est référencé et ne peut pas être fermé", je clique sur "OK" et ... il se ferme.

    Bref ces warnings ne servent à rien, sauf à être pénibles.

    Quelqu'un saurait me dire quel code écrire pour les desactiver?

    Merci par avance.

  2. #2
    Membre éprouvé Avatar de Brunodm13
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    129
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 129
    Par défaut
    Bonsoir,

    As-tu essayé avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.DisplayAlerts = False
    Dans le cas où tu utilises cette propriété, n'oublie pas de la réactiver à la fin de ton code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.DisplayAlerts = True
    Sinon plus de message d'alerte

    Cordialement.

    Bruno

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut
    Bonjour,

    Merci pour votre réponse.

    En fait cela ne marche pas.

    J'ai pu résoudre la fermeture en ajoutant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ActiveWorkbook.Close
    avant mais j'ai toujours les warnings concernant le lien OLE, malgré
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Application.DisplayAlerts = False
    Il y a-t-il quelque chose à rajouter pour les liens OLE?

  4. #4
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Par défaut
    A mettre avant toute procédure, dans la partie déclaration du module:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Declare Function _
        CoRegisterMessageFilter Lib "OLE32.DLL" _
        (ByVal lFilterIn As Long, _
        ByRef lPreviousFilter) As Long
    Puis, dans la procédure où est appelé le lien OLE:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim lMsgFilter As Long
     
    ' Intercepter les messages OLE
    CoRegisterMessageFilter 0&, lMsgFilter
     
    ' Code faisant un appel OLE
     
    ' Restaurer les messages OLE
    CoRegisterMessageFilter lMsgFilter, lMsgFilter
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mars 2009
    Messages
    106
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Mars 2009
    Messages : 106
    Par défaut
    Bonjour,

    votre solution est parfaite.

    Merci mille fois!

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

Discussions similaires

  1. Désactiver des warnings OLE sous Excel
    Par stepham dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/10/2013, 12h52
  2. [VB & Access] Exporter des données sous Excel
    Par wperezrobles dans le forum Access
    Réponses: 1
    Dernier message: 20/09/2006, 11h54
  3. Composant permettant de faire des graphes sous Excel
    Par PrinceMaster77 dans le forum ASP
    Réponses: 2
    Dernier message: 25/10/2005, 22h13
  4. Activation des macros sous Excel
    Par Igloobel dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 10/10/2005, 11h44

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