Hello,
I'm altering a code I have found to mail a sheet to a specific email address, where the email address itself is in the current sheet.
Most of this code was patchwork from examples I have found, and works if I enter an address in manually, though now I'm trying to have it based off of a particular cell in the sheet.
The code I have now is:
What's listed in bold is usually "emailadress@place.com"
However this example returns the error:
Run-time error '1004': Application definite or object-defined error.
I'm not sure what I'm missing but any advice correction or direction would be greatly appreciated. Thanks!
I'm altering a code I have found to mail a sheet to a specific email address, where the email address itself is in the current sheet.
Most of this code was patchwork from examples I have found, and works if I enter an address in manually, though now I'm trying to have it based off of a particular cell in the sheet.
The code I have now is:
Rich (BB code):
Sub Mail_Range()
' Works in Excel 2000, Excel 2002, Excel 2003, Excel 2007, Excel 2010, Outlook 2000, Outlook 2002, Outlook 2003, Outlook 2007, Outlook 2010.
Dim Source As Range
Dim Dest As Workbook
Dim wb As Workbook
Dim TempFilePath As String
Dim TempFileName As String
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim OutApp As Object
Dim OutMail As Object
Set Source = Nothing
On Error Resume Next
Set Source = Range("A1:cx550").SpecialCells(xlCellTypeVisible)
On Error GoTo 0
If Source Is Nothing Then
MsgBox "The source is not a range or the sheet is protected. " & _
"Please correct and try again.", vbOKOnly
Exit Sub
End If
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
Set wb = ActiveWorkbook
Set Dest = Workbooks.Add(xlWBATWorksheet)
Source.Copy
With Dest.Sheets(1)
.Cells(1).PasteSpecial Paste:=8
.Cells(1).PasteSpecial Paste:=xlPasteValues
.Cells(1).PasteSpecial Paste:=xlPasteFormats
.Cells(1).Select
Application.CutCopyMode = False
End With
TempFilePath = Environ$("temp") & "\"
TempFileName = "Selection of " & wb.Name & " " _
& Format(Now, "dd-mmm-yy h-mm-ss")
If Val(Application.Version) < 12 Then
' You are using Excel 2000 or 2003.
FileExtStr = ".xls": FileFormatNum = -4143
Else
' You are using Excel 2007 or 2010.
FileExtStr = ".xlsx": FileFormatNum = 51
End If
Set OutApp = CreateObject("Outlook.Application")
Set OutMail = OutApp.CreateItem(0)
With Dest
.SaveAs TempFilePath & TempFileName & FileExtStr, _
FileFormat:=FileFormatNum
On Error Resume Next
With OutMail
.To = ActiveSheet.Range("h46").Cells.Value
.CC = ""
.BCC = ""
.Subject = "Updated comments and/or professional attributes"
.Body = "This displays so that you know the button has worked, although you still need to send this email if you want me to get the changes." & vbNewLine & vbNewLine & "You only need to send this once for all of changes you make. Thanks!" & vbNewLine & vbNewLine
.Attachments.Add Dest.FullName
.Display
End With
On Error GoTo 0
.Close SaveChanges:=False
End With
Kill TempFilePath & TempFileName & FileExtStr
Set OutMail = Nothing
Set OutApp = Nothing
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
End Sub
However this example returns the error:
Run-time error '1004': Application definite or object-defined error.
I'm not sure what I'm missing but any advice correction or direction would be greatly appreciated. Thanks!