设置为Outlook邮件中的字段到Excel单元格值

时间:2017-03-20 14:45:18

标签: excel vba excel-vba outlook

我借用Ron De Bruin的代码将选择从工作表发送给电子邮件收件人。

我想从工作表中的一个单元格中指定它发送到的地址,该单元格由数据输入(来自另一个工作表的vlookup)选择。

如何将to = "email address"替换为活动工作表中单元格的值?

Sub Mail_Selection()
    ' 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
    Dim Recip As String

    Set Source = Nothing
    On Error Resume Next
    Set Source = Selection.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

    If ActiveWindow.SelectedSheets.Count > 1 Or _
       Selection.Cells.Count = 1 Or _
       Selection.Areas.Count > 1 Then
        msgBox "An Error occurred :" & vbNewLine & vbNewLine & _
               "You selected more than one sheet." & vbNewLine & _
               "You selected only one cell." & vbNewLine & _
               "You selected more than one area." & vbNewLine & vbNewLine & _
               "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, Excel 2002, Excel 2003, Excel 2007, or Excel 2010.
        FileExtStr = ".xls": FileFormatNum = -4143
    Else
        ' You are using Excel 2000, Excel 2002, Excel 2003, Excel 2007, or Excel 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 = "email.address.com"
            .CC = ""
            .BCC = ""
            .Subject = "This is the Subject line"
            .Body = "Hi there"
            .Attachments.Add Dest.FullName
            ' You can add other files by uncommenting the following statement.
            '.Attachments.Add ("C:\test.txt")
            ' In place of the following statement, you can use ".Display" to
            ' display the e-mail message.
            .Send
        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

3 个答案:

答案 0 :(得分:0)

虽然我不确定你尝试了什么,但我会这样做。

Dim emailRange as Range
Set emailRange = 'Insert your range here, not sure what "data inputer" is
OutMail.to = emailRange.Value

答案 1 :(得分:0)

您需要更改以下代码行:

.to = "email.address.com"

以下一个:

.To = ActiveCell.Value

答案 2 :(得分:0)

我现在通过添加以下内容得到了答案;

'Set the EmailAddressVariable to the value in the approvals worksheet in cell A1
Dim EmailAddressVariable As String
EmailAddressVariable = Sheets("Sheet1").Range("A1").Value
'next point the .to statement to the variable
.to = EmailAddressVariable

唯一的问题是我必须将EmailAddressVariable =语句置于以下语句之上;

Set wb = ActiveWorkbook
Set Dest = Workbooks.Add(xlWBATWorksheet)

现在它有魅力 - 感谢BellyGas在Excel论坛上发布!

我希望这对别人有用。