通过Excel宏发送电子邮件时绕过Outlook安全性

时间:2017-11-23 14:12:33

标签: excel vba excel-vba vbscript outlook

我已经完成了一个自动提醒,可以从Excel发送电子邮件,由VBS文件(放在StartUp文件夹中)触发。当我打开我的电脑时,会触发提醒,它应该发送电子邮件,但我有一个安全错误。

这是Excel宏:

Sub Email()
Dim aOutlook As Object
Dim aEmail As Object
Dim i As Integer
For i = 1 To 100      
If Cells(i, 3).Value = Date And IsEmpty(Cells(i, 7)) Then  
        Set aOutlook = CreateObject("Outlook.Application") 
        Set aEmail = aOutlook.CreateItem(0)
        aEmail.Importance = 2
        aEmail.Subject = ActiveSheet.Cells(i, 4)
        aEmail.Body = ActiveSheet.Cells(i, 5)
        aEmail.To = ActiveSheet.Cells(i, 6)
        aEmail.Send
        Cells(i, 7).Value = "Sent: " & Now
End If
Next i
End Sub

这是VBS文件:

Dim xlApp, xlBook
Set wshShell = CreateObject( "WScript.Shell" )
Set xlApp = CreateObject("Excel.Application") 
userName = wshShell.ExpandEnvironmentStrings( "%UserName%" )
Set xlBook = xlApp.Workbooks.Open("C:\Users\" + userName + "\Desktop\RM.xlsm", 0, False) 
xlApp.Application.Run "Email"
xlBook.Save
xlBook.Close
xlApp.Quit 
Set xlApp = Nothing
Set xlBook = Nothing

如何通过在我的宏中添加更多内容来绕过此错误? error
(我已经尝试了谷歌的所有代码,但它们都不起作用。我也不想在Outlook设置或Windows Reg上进行任何更改。)

2 个答案:

答案 0 :(得分:1)

您有几个选择:

  1. 如果您可以控制运行代码的环境,则安装最新的防病毒软件(Outlook不会显示提示)
  2. 扩展MAPI(C ++或Delphi,不适用于VB脚本)。但是,您可以使用类似Redemption的包装器,它使用扩展MAPI,但可以从任何语言(包括VBS)访问。
  3. ClickYes这样的产品。
  4. 有关讨论和可用选项列表,请参阅http://www.outlookcode.com/article.aspx?id=52

答案 1 :(得分:0)

更新防病毒安全后再试一次。

enter image description here