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 :

Envoyer un mail par OUTLOOK 2013 avec une image dans le corps de texte


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Octobre 2011
    Messages : 4
    Par défaut Envoyer un mail par OUTLOOK 2013 avec une image dans le corps de texte
    Bonjour,

    En recopiant des bouts de code à gauche et droite, j'ai réussi à coder une macro sous EXCEL qui envoie des mails avec des pièces jointes. J'aimerais ajouter une image dans le corps de texte mais je suis perdu...
    J'ai trouvé la syntaxe ci-dessous, mais le corps de texte du mail reçu contient seulement une croix rouge encadrée. :

    Nom : image.jpg
Affichages : 1008
Taille : 1,9 Ko
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Set OutApp = CreateObject("Outlook.Application")
    Set OutMail = OutApp.CreateItem(0)
    OutMail.HTMLBody =  "<BODY><br><br><IMG src=cid:image></BODY>"
    la variable "image" contient "C:\user\image.gif"

    Merci pour votre aide

    jlr

  2. #2
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 681
    Par défaut
    Bonjour,

    Tout ce qui est entre "" est considéré par VBA comme du texte, donc ici:"<BODY><br><br><IMG src=cid:image></BODY>" ta variable est ignorée et donc Outlook ne trouve pas l'image.

    essaye comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Set OutApp = CreateObject("Outlook.Application")
    Set OutMail = OutApp.CreateItem(0)
    image = "D:\image\picto.bmp"
    OutMail.HTMLBody = "<BODY><br><br><IMG src=" & image & "></BODY>"
    OutMail.display

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Octobre 2011
    Messages : 4
    Par défaut
    Bonjour halaster08,

    Merci beaucoup pour ta réponse !
    J'ai mis ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Set OutApp = CreateObject("Outlook.Application")
    Set OutMail = OutApp.CreateItem(0)
    image = cheminImage & " \ " & imageTest
    OutMail.HTMLBody "<BODY><br><br><IMG src=" & image & "></BODY>"
    OutMail.display
    Avec la bonne syntaxe (ajout des doubles quotes pour la variable "image"), j'ai la même croix rouge.
    Par rapport à ce que j'avais écrit, à quoi sert "cid" dans la commande "<IMG src=cid:" ?

    En ajoutant ".display", la croix rouge disparait, mais il n'y a rien à la place
    A quoi sert cette commande ?

    Merci !
    jlr

  4. #4
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 681
    Par défaut
    Citation Envoyé par jlr78fr Voir le message
    Par rapport à ce que j'avais écrit, à quoi sert "cid" dans la commande "<IMG src=cid:" ?
    Aucune idée, c'est pour ça que je l'ai viré (je n'ai aucune notion de html)

    En ajoutant ".display", la croix rouge disparait, mais il n'y a rien à la place
    A quoi sert cette commande ?
    .display c'est pour afficher ton couriel

    Chez moi le code proposé fonctionne avec le chemin vers une image qui existe bien.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    image = cheminImage & " \ " & imageTest
    Quels sont les valeurs de cheminImage et imageTest au moment de l'erreur?
    essaye d'ajouter ceci pour voir si le chemin correspond bien a ce que tu attendais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    msgbox cheminImage & " \ " & imageTest
    Si tu essaye avec image = "C:\user\image.gif" ça fonctionne ?

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Octobre 2011
    Messages : 4
    Par défaut
    Le problème est que je n'ai aucun message d'erreur.

    En fait, la macro va sélectionner des cellules dans une feuille et en faire une image (imageTest="image.gif"= qui est stockée dans le répertoire "cheminImage" (C:\...\...), et c'est cette image que je veux insérer dans le corps du mail.

    Si je mets le chemin en dur, j'ai la même chose, c'est à dire rien dans le corps du mail.

    Par contre, j'ai remarqué que j'avais écrit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .HTMLBody "<BODY><br><br><IMG src=" & image & "></BODY>"
    avec la variable image typée en "Objects"
    En ajoutant un espion sur cette variable, j'ai vu que sa valeur était "nothing". Et un peu plus haut dans le code, j'avais mis en commentaire la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set image = attach.Add(cheminImage & "\" & imageTest)
    En dé-commentant cette ligne, ça fonctionne !

    Bon par contre, je n'ai pas vraiment compris comment ce code fonctionne .....

    En tout cas, merci beaucoup pour ton aide !!

    Il existe un bouquin pour apprendre comment faire ce genre de programme mélangeant HTML et VBA ?

    jlr

Discussions similaires

  1. [AC-2010] Envoyer un mail sous access 2010 avec une ou plusieurs annexes
    Par bigounet dans le forum Access
    Réponses: 3
    Dernier message: 10/12/2012, 14h46
  2. Envoyer un email avec une image dans le corps du mail
    Par nitch01 dans le forum Langage
    Réponses: 1
    Dernier message: 04/01/2012, 08h36
  3. Envoyer un mail avec une image dans le corps du mail
    Par tkoprowski dans le forum Android
    Réponses: 1
    Dernier message: 24/08/2011, 17h03
  4. Réponses: 3
    Dernier message: 06/12/2008, 19h34
  5. batch - Envoyer un mail par outlook express
    Par koKoTis dans le forum Windows
    Réponses: 5
    Dernier message: 16/08/2006, 08h44

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