VBA Email from within Excel got it kinda working but...

DipDip

Board Regular
Joined
Jan 23, 2015
Messages
76
Office Version
  1. 2016
Platform
  1. Windows
Hiya All,
I have spent hours looking over the net trying to get this to work but can't seem to figure it out. What I have is a daily meeting notes page that I fill in everyday in our meetings. This is on sheet 1. I have managed to work out how to convert this page to PDF then send out to a pre-specified list that was kept within the code. However, I have realised that it needs to be a dynamic list as people leave and new people start etc.

I have got the following to kinda work. My issue is that it stops at the third person, due to the gap. However, I would like to keep these gaps as they will get filled once we have filled all vacancies.

Any help would be greatly appreciated and many thanks in advance for anything you can suggest.

On the second sheet, I have the following setup:

[TABLE="class: grid, width: 500, align: left"]
<tbody>[TR]
[TD]Manager@hotmail.com[/TD]
[TD]Bob[/TD]
[TD]Manager[/TD]
[/TR]
[TR]
[TD]Clinicallead@hotmail.com[/TD]
[TD]Jane[/TD]
[TD]Clinical Lead[/TD]
[/TR]
[TR]
[TD]nurse1@hotmail.com[/TD]
[TD]Sarah[/TD]
[TD]Nurse 1[/TD]
[/TR]
[TR]
[TD][/TD]
[TD][/TD]
[TD]Nurse 2[/TD]
[/TR]
[TR]
[TD][/TD]
[TD][/TD]
[TD]Nurse 3[/TD]
[/TR]
[TR]
[TD]LeadHCA@hotmail.com[/TD]
[TD]Stefani[/TD]
[TD]Lead HCA[/TD]
[/TR]
[TR]
[TD][/TD]
[TD][/TD]
[TD]Senior HCA[/TD]
[/TR]
[TR]
[TD]me@hotmail.com[/TD]
[TD]Dipam[/TD]
[TD]Finance[/TD]
[/TR]
[TR]
[TD]hr@hotmail.com[/TD]
[TD]Tracy[/TD]
[TD]HR[/TD]
[/TR]
</tbody>[/TABLE]

Here is my code:

Code:
Sub Email()
'
Dim PDF As String
ChDir "C:\Meetings\"
strDate = Format(Date, "ddmmyy")
PDF_File = "Meeting " & strDate & ".pdf"
    
    ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, Filename:=PDF_File, _
        Quality:=xlQualityStandard, IncludeDocProperties:=True, _
        IgnorePrintAreas:=False, OpenAfterPublish:=False


Sheet2.Activate


Dim OutLookApp As Object
Dim OutLookMailItem As Object
Dim myAttachments As Object
Dim strTo$
Dim strToFinal
Dim i%
strTo = "": i = 1


Do
strTo = strTo & Cells(i, 1).Value & "; "
i = i + 1
Loop Until IsEmpty(Cells(i, 1))
strToFinal = Mid(strTo, 1, Len(strTo) - 2)


Set OutLookApp = CreateObject("Outlook.application")
Set OutLookMailItem = OutLookApp.CreateItem(0)
Set myAttachments = OutLookMailItem.Attachments


With OutLookMailItem
.To = strToFinal
.Subject = "Today's Meeting Notes"
.Body = "Hi All," & vbLf & vbLf _
& "Please find the notes from today's meeting" & vbLf & vbLf _
& "Regards" & vbLf & vbLf _
& "" & vbLf & vbLf _
& "" & vbLf _
& "Dipam" & vbLf _
& "Finance" & vbLf _
& "http://www.mywork.com/"




myAttachments.Add "C:\Meetings\" & PDF_File
.display
End With


Set OutLookMailItem = Nothing
Set OutLookApp = Nothing
       
Kill "C:\Meetings\" & PDF_File


Sheet1.Activate


End Sub

Cheers again

Dipam :)
 

Excel Facts

Round to nearest half hour?
Use =MROUND(A2,"0:30") to round to nearest half hour. Use =CEILING(A2,"0:30") to round to next half hour.
hello,

looks like your code has problem at Do Loop:

Loop Until IsEmpty(Cells(i, 1))

instead you could use for each loop:
1)find last cell that is filled with ( Cells(rows.count,1).end(xlup).row
2) set range LoopRng = range("A1",cells(LastRow,1))
3) then do loop for each cell in LoopRng;
4) in loop include if cell is empty to jump to next: if isempty(cell) then next cell

think it might help
 
Upvote 0
Thanks for that. I've tried looking into what you advised, but I am not getting anywhere. Probably because I don't fully understand it all and try my best to figure stuff out as I go along.

This is what I have so far from what you said and then trying to google how to implement it...

Code:
Dim LastRow As Long
    With Worksheet.Sheet2
        LastRow = .Cells(.Rows.Count, "A").End(xlUp).Row
        
Set looprng = Range("A1", Cells(LastRow, 1))


Do
strTo = strTo & Cells(i, 1).Value & "; "
i = i + 1
For Each cell In looprng
Loop Until IsEmpty(cell)
Next cell
strToFinal = Mid(strTo, 1, Len(strTo) - 2)
 
Upvote 0
Code:
Sub Email()'
Dim PDF As String
ChDir "C:\Meetings\"
strDate = Format(Date, "ddmmyy")
PDF_File = "Meeting " & strDate & ".pdf"
    
    ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, Filename:=PDF_File, _
        Quality:=xlQualityStandard, IncludeDocProperties:=True, _
        IgnorePrintAreas:=False, OpenAfterPublish:=False




Sheet2.Activate




Dim OutLookApp As Object
Dim OutLookMailItem As Object
Dim myAttachments As Object
Dim strTo$
Dim strToFinal
Dim i%
strTo = "": i = 1
Dim LCell As Range
Dim LoopRng As Range
Dim Cell As Range




Set LCell = Sheet2.Cells(Sheet2.Rows.Count, "A").End(xlUp)
Set LoopRng = Sheet2.Range("A1", LCell)




For Each Cell In LoopRng
    If IsEmpty(Cell) = True Then
        GoTo JumpHere
    Else
        strTo = strTo & Cells(i, 1).Value & "; "
        i = i + 1
    End If
JumpHere:
Next Cell


strToFinal = Mid(strTo, 1, Len(strTo) - 2)




Set OutLookApp = CreateObject("Outlook.application")
Set OutLookMailItem = OutLookApp.CreateItem(0)
Set myAttachments = OutLookMailItem.Attachments




With OutLookMailItem
.To = strToFinal
.Subject = "Today's Meeting Notes"
.Body = "Hi All," & vbLf & vbLf _
& "Please find the notes from today's meeting" & vbLf & vbLf _
& "Regards" & vbLf & vbLf _
& "" & vbLf & vbLf _
& "" & vbLf _
& "Dipam" & vbLf _
& "Finance" & vbLf _
& "http://www.mywork.com/"








myAttachments.Add "C:\Meetings\" & PDF_File
.display
End With




Set OutLookMailItem = Nothing
Set OutLookApp = Nothing
       
Kill "C:\Meetings\" & PDF_File




Sheet1.Activate




End Sub

Try This one
 
Upvote 0
Managed to figure this out with such a simple method. Highlighted the key bits in BOLD.

Just change the sheet name email to the name of the sheet where the email addresses are kept, and the range to the range in your worksheet. It ignores blanks and just adds in what is relevant.

Rich (BB code):
Sub Email()
'
   
Dim OutLookApp As Object
Dim OutLookMailItem As Object
Dim myAttachments As Object

Set OutLookApp = CreateObject("Outlook.application")
Set OutLookMailItem = OutLookApp.CreateItem(0)
Set myAttachments = OutLookMailItem.Attachments


With Worksheets("Email")
        EmailTo = Join(Application.Transpose(.Range("C6:C23").Value), ";") & ";"
    End With

With OutLookMailItem
.To = EmailTo
.Subject = "Today's Meeting Notes"
.Body = "Hi All," & vbLf & vbLf _
& "Please find the notes from today's meeting" & vbLf & vbLf _
& "Regards" & vbLf & vbLf _
& "" & vbLf & vbLf _
& "" & vbLf _
& "Dipam"

.send
End With


Set OutLookMailItem = Nothing
Set OutLookApp = Nothing
       
End Sub
 
Last edited by a moderator:
Upvote 0
Solution
Put:

Code:
    For i = 1 To 9
        strTo = strTo & Cells(i, 1).Value & "; "
    Next

in place of:

Code:
Do
strTo = strTo & Cells(i, 1).Value & "; "
i = i + 1
Loop Until IsEmpty(Cells(i, 1))


where For i = 1 to 9 are the row numbers of the email addresses.
 
Upvote 0

Forum statistics

Threads
1,225,757
Messages
6,186,848
Members
453,379
Latest member
gabriellegonzalez

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top