The code I’m sharing with you today will enable you to send an email using VBA through Outlook. It uses early binding so you will need to use a reference to Outlook. You may need to look into what version(s) Outlook will be available to your users.
As well as the subject and message body the routine allows you to specify the To, Cc and Bcc fields within a standard email format.
The example below shows the code to attach four files using four different formats: Insert the file, insert a shortcut to the file, Embed and OLE.
The code could easily be changed to loop through arrays or collections of values for many of these fields.
Sub SendAnEmailWithOutlook()'-- Requires a reference to the Microsoft Outlook 8.0 Object Library or higher --
' Creates and sends a new e-mail message with Outlook
Dim OLF As Outlook.MAPIFolder, olMailItem As Outlook.MailItem
Dim ToContact As Outlook.Recipient
Set OLF = GetObject("", "Outlook.Application").GetNamespace("MAPI").GetDefaultFolder(olFolderInbox)
Set olMailItem = OLF.Items.Add ' creates a new e-mail message
With olMailItem
' message subject
.Subject = "This where the subject text goes..."
' add a recipient
Set ToContact = .Recipients.Add("name@org.net")
' add another recipient
Set ToContact = .Recipients.Add("name@org.net")
' set latest recipient as CC
ToContact.Type = olCC
' add another recipient
Set ToContact = .Recipients.Add("name@org.net")
' set latest recipient as BCC
ToContact.Type = olBCC
' the message text with a line break
.Body = "email message"
' insert attachment
.Attachments.Add "C:\FolderName\Filename.txt", olByValue, , "filename goes here"
' insert shortcut
.Attachments.Add "C:\FolderName\Filename.txt", olByReference, , "Shortcut to Attachment"
' embedded attachment
.Attachments.Add "C:\FolderName\Filename.txt", olEmbeddeditem, , "Embedded Attachment"
' OLE attachment
.Attachments.Add "C:\FolderName\Filename.txt", olOLE, , "OLE Attachment"
.OriginatorDeliveryReportRequested = False ' True would be delivery confirmation
.ReadReceiptRequested = False ' True would be read confirmation
'.Save ' saves the message for later editing
'.Display ' displays the email message for editing
.Send ' sends the e-mail message (puts it in the Outbox)
End With
Set ToContact = Nothing
Set olMailItem = Nothing
Set OLF = Nothing
End Sub
Hope the text wrapping doesn’t make it too awkward to read.
As always, if you have any questions do let us know via the comments section.
Edit (18-Dec-2010): Due to a ‘technical’ error this blog entry has changed from it’s original version. The original explained how to send an email through Outlook using late binding, this post will be re-written and posted again soon. Apologies for any inconvenience this may cause.
No comments:
Post a Comment
Please, no purely anonymous comments, they will be deleted; always use a name for ease of reference by other commenters.