问题
I copied the whole block of code from How can I use Outlook to send email to multiple recipients in Excel VBA and added a signature at the end of the email message.
With OutMail
.Display
End With
Signature = OutMail.Body
With OutMail
.To = sTo
.CC = sCC
.BCC = ""
.Subject = Worksheets("MassEmail").Range("A2") & " WW" & Worksheets("MassEmail").Range("B1")
sHTML = "<HTML><BODY><FONT face=""Calibri, Arial"">"
sHTML = sHTML & "<p style=""font-size:11pt"">Hi,</p>"
sHTML = sHTML & "<p style=""font-size:11pt"">Here is the RMA list WW" & Worksheets("MassEmail").Range("B1") & ". Please review.</p>"
sHTML = sHTML & "<pre style=""font-size:11pt;font-family:Calibri,Arial""> Total: </pre>"
.HTMLBody = sHTML & Signature
.HTMLBody = .HTMLBody & "</FONT></BODY></HTML>"
End With
This is how the signature should look.
data:image/s3,"s3://crabby-images/0f6fd/0f6fd2222c358230e92c1ef2a964cf049f9bd674" alt=""
The output is ok except the signature.
data:image/s3,"s3://crabby-images/d9183/d91833ea41281f9ed831b32bf5886fd1476cfa76" alt=""
I tried changing .htmlbody to .body, but results are worse.
The output with .body.
data:image/s3,"s3://crabby-images/1194b/1194b5515a2b25ee739e64f845a25c18f8227b41" alt=""
I'm using Excel/Outlook 2007.
回答1:
you need to set the format of the messaage to RichText or HTMLFormat
something like olFormatHTML or olFormatRichText
then use MailItem.HTMLBody="...."
there is more information on VBA MVP Legend Ron De Bruin's website
Example Code for sending mail from Excel
来源:https://stackoverflow.com/questions/15758300/keep-formatting-of-outlook-signature-when-creating-mail