Hi everyone
I am currently using a VBA from Ron de Bruin to send a worksheet via email, which is working fine. However, if I can I want to add the current month (when the email is sent) to the body of the email. Below is the code I have, and where it says [MONTH] that's where I need the month to go. I have tried "Please find attached " & Format(Now, "mmm-yy") "rest of message....."
but this didn't work. Had an error saying expected end of line or something like that. Any help will be greatly appreciated!
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim Sourcewb As Workbook
Dim Destwb As Workbook
Dim TempFilePath As String
Dim TempFileName As String
Dim OutApp As Object
Dim OutMail As Object
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
Set Sourcewb = ActiveWorkbook
'Copy the ActiveSheet to a new workbook
ActiveSheet.Copy
Set Destwb = ActiveWorkbook
'Determine the Excel version and file extension/format
With Destwb
If Val(Application.Version) < 12 Then
'You use Excel 97-2003
FileExtStr = ".xls": FileFormatNum = -4143
Else
'You use Excel 2007-2013
FileExtStr = ".xlsb": FileFormatNum = 50
End If
End With
' 'Change all cells in the worksheet to values if you want
' With Destwb.Sheets(1).UsedRange
' .Cells.Copy
' .Cells.PasteSpecial xlPasteValues
' .Cells(1).Select
' End With
' Application.CutCopyMode = False
'Save the new workbook/Mail it/Delete it
TempFilePath = Environ$("temp") & "\"
TempFileName = "Click N Claim Report" & " " & Format(Now, "mmm-yy")
Set OutApp = CreateObject("Outlook.Application")
Set OutMail = OutApp.CreateItem(0)
With Destwb
.SaveAs TempFilePath & TempFileName & FileExtStr, FileFormat:=FileFormatNum
On Error Resume Next
With OutMail
.to = ""
.CC = ""
.BCC = ""
.Subject = "CPD Allowances via CnC" & " " & Format(Now, "mmm-yy")
.Body = "Dear Expenses Team," & vbNewLine & vbNewLine & _
"Please find attached the [MONTH] report showing new delegates who should be claiming their allowances." & vbNewLine & vbNewLine & _
"Please can you provide the Claim report showing the past three months expenses [MONTH] to [MONTH]." & vbNewLine & vbNewLine & _
"Thank you"
.Attachments.Add Destwb.FullName
'You can add other files also like this
'.Attachments.Add ("C:\test.txt")
.Display 'or use .Send
End With
On Error GoTo 0
.Close savechanges:=False
End With
'Delete the file you have send
Kill TempFilePath & TempFileName & FileExtStr
Set OutMail = Nothing
Set OutApp = Nothing
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
Bookmarks