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

Bibliothèques tierces Python Discussion :

pywin32 :: Appeler Macro dans Outlook


Sujet :

Bibliothèques tierces Python

  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 56
    Points : 38
    Points
    38
    Par défaut pywin32 :: Appeler Macro dans Outlook
    Bonjour,

    J'essaie actuellement d'appeler une macro dans mon Outlook 2003, j'ai installé pywin32 et j'ai fouillé longuement sur internet mais je ne trouve pas de solution qui fonctionne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    class OutL:
        def __init__(self):
        oOutlook = win32.gencache.EnsureDispatch("Outlook.Application")
        oOutlook.run('maFonction')
    J'ai aussi essayé

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    class OutL:
        def __init__(self):
        oOutlook = win32.gencache.EnsureDispatch("Outlook.Application")
        o = oOutlook.Application
        o.run('maFonction')
    J'ai toujours le même problème

    AttributeError: '<win32com.gen_py.Microsoft Outlook 11.0 Object Library._Application instance at 0x21542128>' object has no attribute 'run'

    Auriez-vous une idée pour appeler directement une macro VBA via Python ?

    Merci

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 235
    Points : 36 684
    Points
    36 684
    Par défaut
    Auriez-vous une idée pour appeler directement une macro VBA via Python ?
    L'API COM de win32 est la même pour tous les "langages".
    La question est "comment faire avec VB ou C#?" puis traduire en Python.

    Ceci dit, appeler une macro VB depuis l'extérieur pour Word, Excel, Outlook,... est toujours un peu différent voire "non supporté", "mal documenté",...

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 56
    Points : 38
    Points
    38
    Par défaut
    ????

    En C#, j'ai appelé ma macro comme ceci.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
                    Type mtype;
     
                   Outlook.Application oApp = new Outlook.Application();
     
                    mtype = oApp.GetType();
                    string[] strArr;
                    strArr = new string[5];
                    strArr[0] = "Courriel@Destinaire.com";
                    strArr[1] = "";
                    strArr[2] = "";
                    strArr[3] = "Titre";
                    strArr[4] = "Contenu";
                    mtype.InvokeMember("MaFonction", System.Reflection.BindingFlags.InvokeMethod, null, oApp, strArr);

    Et sa fonctionne #1

    Il n'y a pas de façon d'appeler les mêmes methodes en python, je ne vois donc pas votre point, ni même l'intêret de votre réponse qui n'en est pas une mais merci pareil

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 235
    Points : 36 684
    Points
    36 684
    Par défaut
    Salut,

    Vu le code qui "marche", la traduire en Python par oOutlook.MaFonction(...) devrait suffire i.e. laisser la couche win32com effectuer le mapping de la fonction et de ses arguments avec la couche COM plutôt que de le faire "explicitement" comme dans le code C#


    Mais je doute que vous ayez trouvé cela dans la documentation µSoft, i.e c'est juste un hack.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Membre à l'essai
    Inscrit en
    Février 2009
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 25
    Points : 19
    Points
    19
    Par défaut
    Voilà :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    import win32com.client 
    import os
     
    o = win32com.client.Dispatch("Outlook.Application")
    destinataires = "nom1@email.com ; nom2@email.com"
    cc = "nom3@email.com"
    bcc = ""
    sujet = "Le sujet du message"
    message = "Le contenu du message \nBlablablablabla \nYadiyadiyada"
    fileCompletePath = r"D:\temp\monFichier.txt"
    o.FnSendMailSafe(destinataires, cc, bcc, sujet, message, fileCompletePath)

Discussions similaires

  1. [OL-2010] Planificateur de tache lance une macro dans Outlook via vbs
    Par pimberti dans le forum VBA Outlook
    Réponses: 0
    Dernier message: 16/08/2011, 19h09
  2. [XL-2002] Appel macro dans une boucle
    Par zoumzoum59 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 22/02/2010, 15h51
  3. bouton macro dans outlook
    Par emulamateur dans le forum Outlook
    Réponses: 2
    Dernier message: 18/10/2009, 21h15
  4. Appel à macro dans étape data pour modifier table
    Par Filippo dans le forum Macro
    Réponses: 2
    Dernier message: 14/10/2009, 10h00
  5. Macro dans Outlook
    Par beginner2007 dans le forum VBA Outlook
    Réponses: 2
    Dernier message: 31/05/2007, 17h21

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