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 :

VBA Excel vers Outlook champs préremplis [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Coordinator customer support
    Inscrit en
    Octobre 2015
    Messages
    46
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Belgique

    Informations professionnelles :
    Activité : Coordinator customer support
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Octobre 2015
    Messages : 46
    Par défaut VBA Excel vers Outlook champs préremplis
    Bonjour,

    En rapport avec le code VBA disponible ici

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
     
    Option Explicit
     
    '-----------------------------------------------------------------------
    '
    ' Lit le contenu d'un fichier texte et retourne son
    ' contenu
    '
    '-----------------------------------------------------------------------
     
     Public Function ReadFile(sFileName) As String
     
    Dim fso As Object, fFile As Object
    Dim sTemp As String
     
       Set fso = CreateObject("Scripting.FileSystemObject")
     
       Set fFile = fso.OpenTextFile(sFileName, 1, False)
     
       sTemp = fFile.ReadAll
     
       fFile.Close
     
       Set fFile = Nothing
     
       ReadFile = sTemp
     
    End Function
     
    '-----------------------------------------------------------------------'
    ' Cette routine va créer une instance de Outlook (si
    ' pas encore démarré) et va ensuite ouvrir une
    ' fenêtre de type mail.   Le corps du message sera
    ' initialisé avec le contenu d'un fichier de type
    ' HTML.   Ce fichier aura été préalablement
    ' créé par la routine SendRangeByMail
    '
    ' Nécessite l'ajout d'une référence vers "Microsoft
    ' Outlook Object Library"
    '
    '-----------------------------------------------------------------------
     
     Sub PrepareOutlookMail(ByVal sFileName As String)
     
    Dim appOutlook As Outlook.Application
    Dim oMail As Outlook.MailItem
     
       Set appOutlook = CreateObject("Outlook.Application")
     
       ' Si Outlook n'était pas ouvert, l'instruction
        ' ci-dessus aura eu pour conséquence de
        ' démarrer Outlook.
        'Ce type de démarrage par automation fait
        'apparaître une fenêtre de sécurité qui demande
        'à l'utilisateur de permettre au programme de
        'continuer.
        '
        'Le message est "A program is trying to send an
        'email.   Do you want to allow..."
        '
        'Dans le cas où l'utilisateur aurait cliqué sur No,
        'l'objet appOutlook est égal à Nothing.  Il est
        'donc impossible de continuer.
     
       If Not (appOutlook Is Nothing) Then
     
          Set oMail = appOutlook.CreateItem(olMailItem)
     
          oMail.HTMLBody = ReadFile(sFileName)
     
          oMail.Display
     
          Set oMail = Nothing
          Set appOutlook = Nothing
     
       End If
     
    End Sub
     
    '-----------------------------------------------------------------------
    '
    ' La routine SendRangeByMail va proposer à
    ' l'utilisateur de sélectionner une plage de cellules
    ' en Excel et va ensuite envoyer cette plage par
    ' mail, dans le corps du mail.
    '
    '-----------------------------------------------------------------------
     
     Sub SendRangeByMail()
     
    Dim rngeSend As Range
     
       With Application
     
          On Error Resume Next
     
          ' Demande à l'utilisateur de sélectionner la
          ' plage de cellule
     
          Set rngeSend = .InputBox(Prompt:="Please select range you wish to send.", Type:=8, Default:=.Selection.Address)
     
          ' rngeSend Is Nothing lorsque l'utilisateur ne fait
          ' aucun choix
     
           If rngeSend Is Nothing Then Exit Sub
     
          On Error GoTo 0
     
          ' Exporte la plage vers un fichier de type HTML;
          ' ceci afin de respecter la mise en page de la
          ' plage
     
          .ActiveWorkbook.PublishObjects.Add(4, "C:\Temp\XLRange.htm", rngeSend.Parent.Name, rngeSend.Address, 0, "", "").Publish True
     
          ' Appelle la routine qui va se charger de créer
          ' un mail
     
          Call PrepareOutlookMail("C:\Temp\XLRange.htm")
     
          ' Le fichier HTML n'est plus nécessaire
     
          Kill "C:\Temp\XLRange.htm"
     
       End With ' With Application
     
    End Sub
    J'aimerai pouvoir remplir de plusieurs adresses mail le champ destinataire, CCI et objet du mail

    Pourriez-vous m'aider à adapter ce code (copié tel quel dans mon projet et fonctionnel :-) )

    Merci pour votre support,

    Damien

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Salut,

    tu peux aisement faire evoluer le code, en ajoutant en parametre ce dont tu as besoin, par exemple :
    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
    Sub PrepareOutlookMail(ByVal sFileName As String,strTo As String,strCc as String,strSubject As String)
    Dim appOutlook As Outlook.Application
    Dim oMail As Outlook.MailItem
    Set appOutlook = CreateObject("Outlook.Application")
       If Not (appOutlook Is Nothing) Then 
          Set oMail = appOutlook.CreateItem(olMailItem)
          oMail.HTMLBody = ReadFile(sFileName)
          oMail.To = strTo
          oMail.Cc = strCc
          oMail.Subject = strSubject
          oMail.Display 
          Set oMail = Nothing
          Set appOutlook = Nothing
       End If
    End Sub
    A toi de poursuivre avec ce dont tu as besoin
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  3. #3
    Membre averti
    Homme Profil pro
    Coordinator customer support
    Inscrit en
    Octobre 2015
    Messages
    46
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Belgique

    Informations professionnelles :
    Activité : Coordinator customer support
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Octobre 2015
    Messages : 46
    Par défaut
    Bonjour,

    Effectivement, c'est aisé

    merci beaucoup

    Damien

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

Discussions similaires

  1. [XL-2010] Publipostage VBA (depuis excel vers outlook)
    Par krokos55 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 05/12/2012, 10h49
  2. Réponses: 6
    Dernier message: 02/05/2011, 08h40
  3. VBA -Copier cellules Excel vers outlook
    Par Rdesfx dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 08/11/2008, 16h29
  4. Vba excel vers outlook
    Par maejor dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/01/2008, 17h53
  5. Importer des données excel vers outlook
    Par faayy dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 17/10/2005, 09h30

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