1 pièce(s) jointe(s)
VBA : Envoi d'un mail Outlook personnalisé
Bonjour,
Je souhaite envoyer à chaque correspondants en charge d'un certain nombre de commerciaux
un mail dont le corps du mail contiendrait le titre + Prénom + Nom du commercial. En sachant que chaque correspondant habite dans une ville et a un nombre de commerciaux différents.
Le mail ne se génère que lorsque la colonne Mail = Oui
Exemple du fichier excel
Pièce jointe 582377
J'ai réussi à faire un code mais le problème est qu' il me génère autant de mail que de ligne à Oui c'est dire 7 au lieu de 6.
Le problème vient du correspondant C qui habite à Bordeaux qui a 2 commerciaux car le code me génère 2 mails au lieu d'un seul.
Par ailleurs , je voudrais que le texte du Body change en fonction du nombre de commercial
Dans le cas d'un seul commercial le corps du mail doit être :
"Bonjour,"
"Comment va votre commercial " saut de ligne
"-" Titre + Prénom + Nom ?"
Dans le cas de plusieurs commerciaux, le corps du mail doit être :
Bonjour,"
"Comment vont vos commerciaux " saut de ligne
"-" Titre + Prénom + Nom ?"
"-" Titre + Prénom + Nom ?"
Ci-dessous le code VBA
Code:
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
| Sub EMAIL()
Dim LEMAIL As Variant
Dim ligne As Integer
Dim xSht As Worksheet
Set xSht = Sheets("Feuil1")
Set LEMAIL = CreateObject("Outlook.Application") 'création d'un objet outlouk
For ligne = 3 To 100
If Range("h" & ligne) = "Oui" Then
With LEMAIL.CreateItem(olMailItem) ' informe le programme que nous voulons envoyer un mail.
.Importance = 2 'Message importante haute
.ReadReceiptRequested = True 'Accusé de lecture
.OriginatorDeliveryReportRequested = True 'Accusé de réception
.Subject = "test " 'le sujet
.SentOnBehalfOfName = "adm@gmail.fr" 'la commande SentOnBehalfOfName
permet de prendre le mail générique
.To = Range("G" & ligne) 'placer l'adresse mail du correspondant
.CC = ""
.Body = "Bonjour," & vbCrLf & vbCrLf & "Comment vont vos commerciaux : " & vbCrLf & vbCrLf & Range("b" & ligne) & Range("c" & ligne) & Range("d" & ligne)
.Display 'afficher le mail avant de l'envoyer sinon placer send pour envoyer
SendKeys "^+{END}", True
SendKeys "{END}", True 'envoi le curseur à la fin du texte
End With
End If
Next ligne
End Sub |
Merci d'avance car je n'ai pas un niveau très élevé pour imbriquer autant de conditions.