Why doesn't my Code work??? Creating a PDF, attaching PDF to email and sending

matthec2

New Member
Joined
Dec 17, 2013
Messages
36
Hello,

I am having trouble with the below code, wondering if anyone can help me.

I found the original solution on an Excel website; I changed it to what I require.

I am trying to select a few worksheets, save as a PDF, then email it to myself.

Funny thing is that this code has worked before for several weeks.

The code keeps crashing at the line ".Attachments.Add PdfFile"

I can see the PDF being created in the Windows folder, but doesn't then get attached to the email. As if the file name or location is wrong?

My assumption is that there is a problem with the PdfName or Title lines - these are the parts of the code I am unfamiliar with.

Any help much appreciated!

Code:
Sub TargetingEmailPDF()
  Dim IsCreated As Boolean
  Dim i As Long
  Dim PdfFile As String, Title As String
  Dim OutlApp As Object
 
  ' Not sure for what the Title is
  Title = Range("A1")
 
  ' Define PDF filename
  PdfFile = ""
  i = InStrRev(PdfFile, ".")
  If i > 1 Then PdfFile = Left(PdfFile, i - 1)
  PdfFile = PdfFile & Range("TargetingEmail").Value & ".pdf"
 
  ' Export activesheet as PDF
  Sheets(Array("Targeting-1", "Targeting-2")).Select
  With ActiveSheet
    .ExportAsFixedFormat Type:=xlTypePDF, Filename:=PdfFile, Quality:=xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False
  End With
    Sheets("LIST").Select
 
  ' Use already open Outlook if possible
  On Error Resume Next
  Set OutlApp = GetObject(, "Outlook.Application")
  If Err Then
    Set OutlApp = CreateObject("Outlook.Application")
    IsCreated = True
  End If
  OutlApp.Visible = True
  On Error GoTo 0
 
  ' Prepare e-mail with PDF attachment
  With OutlApp.CreateItem(0)
   
    ' Prepare e-mail
    .Subject = Range("TargetingEmail").Value
    .To = Range("EmailAddressTo").Value ' <-- Put email of the recipient here
    .CC = "" ' <-- Put email of 'copy to' recipient here
    .Body = "Hi," & vbLf & vbLf _
          & "The report is attached in PDF format." & vbLf & vbLf _
          & "Regards," & vbLf _
          & Application.UserName & vbLf & vbLf
    .[B]Attachments.Add PdfFile
   [/B]
    ' Try to send
    On Error Resume Next
    .Send
    Application.Visible = True
    If Err Then
      MsgBox "E-mail was not sent", vbExclamation
    Else
      MsgBox "E-mail successfully sent", vbInformation
    End If
    On Error GoTo 0
   
  End With
 
  ' Delete PDF file
  Kill PdfFile
 
  ' Quit Outlook if it was created by this code
  If IsCreated Then OutlApp.Quit
 
  ' Release the memory of object variable
  Set OutlApp = Nothing
End Sub
 

Excel Facts

How to find 2nd largest value in a column?
MAX finds the largest value. =LARGE(A:A,2) will find the second largest. =SMALL(A:A,3) will find the third smallest
Thanks for the response, I assumed that was the case, just odd how it has worked previously then has stopped working.

Saving the PDF seems ok as it does appear in the folder. It is the "attachment" line where it doesn't seem to find the location.

Can you amend my code above to show a brief example. The master file is located in our company shared P Drive, about 4 sub folders down.

Many Thanks!
 
Upvote 0
Actually, I've managed to fix this temporarily.

I found that when I copied the file to my desktop, the coding worked. Then I copied the file back to the relevant sub folder.

The issue is definitely in the file location section. Seems that the code works when you initially create the file, but it doesn't like being disturbed.

Hopefully I can work this out when it happens again in the future!
 
Upvote 0

Forum statistics

Threads
1,225,760
Messages
6,186,870
Members
453,380
Latest member
ShaeJ73

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