Email current Active Sheet from Excel 2010

Hi Experts,

I would like a script/marco I can use to email the current active worksheet from excel 2010 via Outlook 2010.

I have the attached script that I used regulally for many years but I dont think it is compatible with 2010.  The attachment should be the name of the worksheet.

can you help bring my script into the future?

Thank you
Sub Mail_ActiveSheet()
' Works in Excel 97 through Excel 2007.
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim Sourcewb As Workbook
Dim Destwb As Workbook
Dim TempFilePath As String
Dim TempFileName As String
 
With Application
  .ScreenUpdating = False
  .EnableEvents = False
End With
 
Set Sourcewb = ActiveWorkbook
' Using ActiveSheet.Copy creates a new workbook with
' the sheet and the file format is the same as the
' original workbook.
' Copy the worksheet 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 are using Excel 97-2003.
     FileExtStr = ".xls": FileFormatNum = -4143
  Else
     ' You are using Excel 2007.
     ' When you use ActiveSheet.Copy to create a workbook,
     ' you are prompted with a security dialog. If you click No
     ' in the dialog, then the name of Sourcewb is the same
     ' as Destwb and you exit the subroutine. You only see this
     ' dialog when you attempt to copy a worksheet from an .xlsm file with macros disabled.
     If Sourcewb.Name = .Name Then
        With Application
           .ScreenUpdating = True
           .EnableEvents = True
        End With
        MsgBox "Your answer is No in the security dialog."
        Exit Sub
     Else
        Select Case Sourcewb.FileFormat
           ' Code 51 represents the enumeration for a macro-free
           ' Excel 2007 Workbook (.xlsx).
           Case 51: FileExtStr = ".xlsx": FileFormatNum = 51
           ' Code 52 represents the enumeration for a
           ' macro-enabled Excel 2007 Workbook (.xlsm).
           Case 52:
              If .HasVBProject Then
                 FileExtStr = ".xlsm": FileFormatNum = 52
              Else
                 FileExtStr = ".xlsx": FileFormatNum = 51
              End If
           ' Code 56 represents the enumeration for a
           ' a legacy Excel 97-2003 Workbook (.xls).
           Case 56: FileExtStr = ".xls": FileFormatNum = 56
           ' Code 50 represents the enumeration for a
           ' binary Excel 2007 Workbook (.xlsb).
            Case Else: FileExtStr = ".xlsb": FileFormatNum = 50
        End Select
     End If
  End If
End With
 
' Change all cells in the worksheet to values, if desired.
''   With Destwb.Sheets(1).UsedRange
''      .Cells.Copy
''      .Cells.PasteSpecial xlPasteValues
''      .Cells(1).Select
''   End With
''Application.CutCopyMode = False
 
'Save the new workbook and then mail it.
  TempFilePath = Environ$("temp") & "\"
  TempFileName = ActiveSheet.Name
 
With Destwb
  .SaveAs TempFilePath & TempFileName, FileFormat:=FileFormatNum
     On Error Resume Next
  .SendMail "", _
     "Subject of email goes here"
     On Error GoTo 0
  .Close SaveChanges:=False
End With
 
' Delete the file you just sent.
Kill TempFilePath & TempFileName & FileExtStr
 
With Application
  .ScreenUpdating = True
  .EnableEvents = True
End With
End Sub

Open in new window

wisematAsked:
Who is Participating?
 
Jerry PaladinoConnect With a Mentor Commented:
You are most likely missing a VBA Reference Library on your installation of Excel.  See this link on Chip Pearson site for an explanation:  Missing References and also a similar discussion at this link: Compile/Reference Errors
0
 
Rgonzo1971Commented:
HI,

works fine for me

in Xl2010 with OL 010

Regards
0
 
wisematAuthor Commented:
Oh, it always fails for me at this line:

 TempFilePath = Environ$("temp") & "\"
0
Cloud Class® Course: Ruby Fundamentals

This course will introduce you to Ruby, as well as teach you about classes, methods, variables, data structures, loops, enumerable methods, and finishing touches.

 
Rgonzo1971Commented:
maybe
 TempFilePath = Environ("temp") & "\"
0
 
wisematAuthor Commented:
No change

Compile error:
Can't find project or library
0
 
wisematAuthor Commented:
Thanks for the pointer, a lot of words to read there, I'll get back to you as soon as I can.
0
 
Jerry PaladinoCommented:
Wisemat  -  Here is some additional reading where I had a similar problem with VBA not properly compiling the code and the suggestion in this EE Question solved it.  Compile Time Error on Common VBA Function.   Hopefully one of two suggestions will help solve your existing issue.
0
 
wisematAuthor Commented:
Thanks for the library info. This was the source of the problem and not the script. It just took a while for me to work it out.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.