Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 5 sur 5
  1. #1
    Invité régulier
    Inscrit en
    novembre 2009
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : novembre 2009
    Messages : 52
    Points : 8
    Points
    8

    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 :
    1
    2
    3
    4
    5
     
    class OutL:
        def __init__(self):
        oOutlook = win32.gencache.EnsureDispatch("Outlook.Application")
        oOutlook.run('maFonction')
    J'ai aussi essayé

    Code :
    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
    Modérateur

    Homme Profil pro
    Architecte technique
    Inscrit en
    juin 2008
    Messages
    5 422
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : juin 2008
    Messages : 5 422
    Points : 8 181
    Points
    8 181

    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

  3. #3
    Invité régulier
    Inscrit en
    novembre 2009
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : novembre 2009
    Messages : 52
    Points : 8
    Points
    8

    Par défaut

    ????

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

    Code :
    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
    Modérateur

    Homme Profil pro
    Architecte technique
    Inscrit en
    juin 2008
    Messages
    5 422
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : juin 2008
    Messages : 5 422
    Points : 8 181
    Points
    8 181

    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

  5. #5
    Invité régulier
    Inscrit en
    février 2009
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : février 2009
    Messages : 25
    Points : 8
    Points
    8

    Par défaut

    Voilà :

    Code :
    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)

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •