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 :

de l'usage de message Outlook avec Excel [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 100
    Par défaut de l'usage de message Outlook avec Excel
    Bonjour à tous,

    J'ai un petit programme qui génère un message dans Outlook.
    Je voudrais, après avoir généré ce message et avant de l'envoyer, qu'Excel revienne en avant-plan.
    Pour cela j'utilise le petit programme ci-après :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    Hwnd = FindWindow(vbNullString, "Microsoft Excel - Mon programme"
     
           Do While Hwnd1 = 0
                Hwnd1 = FindWindow(vbNullString, "Mon message Outlook - Message (HTML) ")
                newHour = Hour(Now())
                newMinute = Minute(Now())
                newSecond = Second(Now()) + 1
                waitTime = TimeSerial(newHour, newMinute, newSecond) 'temporisation
                Application.Wait waitTime
            Loop
     
            'Pour ramener Excel au premier plan
            BringWindowToTop Hwnd
            'Affiche en mode "Normal"
            ShowWindow Hwnd, 5
    Cela ne fonctionne pas, vous vous en doutez car sinon je ne vous solliciterais pas. Le message reste en avant plan.

    Quelqu'un pourrait-il m'expliquer pourquoi ?

  2. #2
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Août 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2011
    Messages : 16
    Par défaut
    Bonjour,

    Pour ma part voici comment je traite le problème:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Application.WindowState = xlMinimized
        If OtLk_App.Explorers.Count > 0 Then OtLk_App.ActiveWindow.WindowState = olMaximized
     
        Mail_Item.Display 'Place le mail dans la boite d'envoi
        Application.Wait TimeSerial(Hour(Now()), Minute(Now()), Second(Now()) + 3)
        SendKeys "%{v}", True    If OtLk_App.Explorers.Count > 0 Then OtLk_App.ActiveWindow.WindowState = olMinimized
        Application.WindowState = xlMaximized
    Je te laisse le soin d'adapter le code à ta convenance.

    Cordialement

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 100
    Par défaut
    Bonjour Yersin et merci pour ta réponse

    Si je me débrouille en VBA, je ne suis toutefois pas un pro et certaines commandes me sont obscures voire inconnues notamment celles qui manipulent les objets Application.

    Comment déclares-tu la variable "OtLk_App" ?
    Pourrais-tu m'expliquer la "philosophie" de ta routine ?

    Merci pour ton aide.

  4. #4
    Membre averti
    Homme Profil pro
    Consultant MOA
    Inscrit en
    Août 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant MOA
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2011
    Messages : 16
    Par défaut
    Pour La variable App :
    Puis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set OtLk_App = CreateObject("Outlook.Application")
    Sinon, pour les paramètres de OutLook, il ne faut pas oublié de les mettre en constante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Const olByValue = 1 ' Constante pour l'ajout de pièce jointe
    Const olMaximized = 0 ' Constante pour maximiser OutLook
    Const olMinimized = 1 ' Constante pour minimiser OutLook
    "Philosophie" me semble un bien grand mot. Disons, simplement qu'après avoir préparer le mail, je masque Excel et j'affiche Outlook afin de pouvoir passer le SendKey sans problème, ensuite je rétablie simplement la situation.

    Cette méthode n'est pas parfaite et demande du temps. Essaye de chercher d'autres méthodes, type CDO, qui semble plus viable.

    Yersin

  5. #5
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 100
    Par défaut
    OK, je te remercie pour ton aide.
    Je vais essayer de faire avec cela.
    Cela devrait au moins me familiariser avec la manipulation des objets "Application".

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

Discussions similaires

  1. Automatiser le déplacement de mails dans outlook avec EXCEL
    Par Guiggs dans le forum Général VBA
    Réponses: 0
    Dernier message: 09/07/2013, 09h30
  2. [XL-2007] Automatiser le déplacement de mails dans outlook avec EXCEL
    Par Guiggs dans le forum Excel
    Réponses: 3
    Dernier message: 08/07/2013, 13h24
  3. [XL-2003] Traitement mails outlook avec Excel
    Par sdispro dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 23/11/2011, 18h39
  4. [XL-2000] Modifier Outlook avec Excel
    Par amerex dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 19/07/2009, 13h03
  5. [XL-2000] Création d'un message Outlook avec données Excel
    Par duck94 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 08/04/2009, 17h00

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