【问题标题】:Outlook ItemAdd event on IMAP folder fires only when folder is selectedIMAP 文件夹上的 Outlook ItemAdd 事件仅在选择文件夹时触发
【发布时间】:2013-02-15 00:33:38
【问题描述】:

我在 Outlook VBA 编程方面遇到了一个小问题,想知道是否有解决方案,或者这只是另一个“已知问题”。


上下文

我已配置 Outlook 电子邮件帐户以通过 IMAP 访问我的网络电子邮件提供商。在 Outlook 中,我可以正确查看我的网络电子邮件文件夹。我的提供商的垃圾邮件过滤器将垃圾邮件移动到垃圾邮件文件夹中。

我想自动将放入垃圾邮件文件夹的邮件移动到我本地 pst 文件中的另一个文件夹中。

我让它工作了 99%(通过下面提供的代码供参考)。


问题

我可以看到垃圾邮件文件夹中有邮件(文件夹名称旁边有一个粗体的未读邮件计数),但 ItemAdd 甚至只会在我单击该文件夹时触发。此时,我看到了垃圾邮件文件夹的内容,然后看到所有新的垃圾邮件都被移到了我的本地文件夹中。

除了 ItemAdd 之外,是否还有另一个触发源可以用来运行我的代码而无需单击文件夹?文件夹的未读计数发生变化时是否会触发事件?


技术细节

  • Windows 8 操作系统
  • 使用 Outlook 2002(是的,我知道...)
  • 我是一位经验丰富的 C/C++ 开发人员,但在 VBA 方面的经验很少,而且在 Outlook 方面没有经验。

VBA 代码:

Public WithEvents myItems As Outlook.Items

Public Sub Application_Startup()

    Dim myNameSpace As Outlook.NameSpace
    Const mailboxName As String = "Mail.com"
    Const subfolderName As String = "Spam"


    ' Reference the items in the MAPI spam folder
    ' Because myOlItems is declared "WithEvents" the ItemAdd event will fire below.
    Set myNameSpace = Application.GetNamespace("MAPI")

    On Error GoTo noSpamFolder
    Set myItems = myNameSpace.Folders(mailboxName).Folders(subfolderName).Items
    On Error GoTo 0

    Exit Sub

noSpamFolder:
    MsgBox "Unable to find folder <" & mailboxName & "/" & subfolderName & ">"

End Sub


Private Sub myItems_ItemAdd(ByVal Item As Object)

    Dim suspectFolder As Outlook.MAPIFolder

    ' Check to make sure it is an Outlook mail message, otherwise
    ' subsequent code will probably fail depending on what type
    ' of item it is.
    If TypeName(Item) = "MailItem" Then

       ' Move message to the 'suspect' folder
       On Error GoTo noSuspectFolder
       Set suspectFolder = Outlook.Session.GetDefaultFolder(olFolderInbox).Folders("suspect")
       On Error GoTo 0

       Item.Move suspectFolder

    End If

    Exit Sub

noSuspectFolder:
    MsgBox "Unable to find folder <suspect> as a sub-folder of default inbox folder"
End Sub

【问题讨论】:

  • 你让脚本工作了吗?我正在尝试找到一种方法来在创建日历事件后触发事件,我想这将类似于Outlook.MAPIFolder.itemsAdd,但我并不完全确定。我基本上没有使用 VBscript 的经验,也许你能指出我正确的方向......
  • 与我最初的描述相比没有任何改进,这意味着我仍然需要单击 IMAP 文件夹才能处理其项目。我可以忍受。

标签: vba outlook


【解决方案1】:

我在发送邮件后遇到类似的问题,并使用您的代码执行此任务(谢谢!)。还有几个问题需要解决。

首先,这些项目被移动,但在它们被放入垃圾文件夹后立即移动。这似乎是 IMAP 问题(Gmail),可以通过将邮箱帐户的 Internet 电子邮件设置从“将已删除的项目移动到服务器上的以下文件夹”更改为“标记要删除的项目但不移动它们”来解决自动”。

第二个挑战是,和你一样,触发代码来完成它的工作。在帐户配置中,保存已发送电子邮件选项被禁用(因为这是由 Gmail 服务器自动执行的)。我需要将已发送项目 (MAPI) 文件夹与发送项目 (IMAP) 文件夹同步。 我通过为此电子邮件帐户(在所有帐户组中)配置“发送/接收”组并选择“已发送邮件”文件夹来实现此目的

现在此文件夹已同步,无需打开文件夹进行同步。我希望这也能解决您的问题。

彼得

【讨论】:

  • 那是丢失的物品,谢谢!将 IMAP 帐户中的垃圾邮件文件夹添加到发送/接收组后,刷新时会触发 ItemAdd 事件。 :)
【解决方案2】:

这是有道理的 - Outlook 中的 IMAP 提供程序仅在通过 Outlook 对象模型选择或访问文件夹时同步文件夹。
我认为除了每隔一段时间轮询一次文件夹(并在两次点击之间释放 MAPIFolder 对象)之外,您无能为力

【讨论】:

  • 这就是我的想法,但未读计数确实更新的事实告诉我,Outlook 知道有新邮件,即使它实际上还没有获取它们。有什么方法可以获取这些信息?
  • MAPIFolder.FolderChange 事件是否在父文件夹上触发?您可以在 OutlookSpy 中看到事件(选择父文件夹,单击 OutlookSpy 工具栏上的文件夹按钮,选择文件夹属性,单击浏览,转到事件选项卡)?
  • 我无法按照您的指示进行操作,我似乎没有得到您所期望的结果。这是我所做的:1)下载并安装了 OutlookSpy 2.15(不是最新的,因为我正在运行 Outlook 2002)2)如果我选择垃圾邮件文件夹的父文件夹,单击 Outlook 间谍上的文件夹项目会产生没有动作。父文件夹是帐户的主文件夹,在 Outlook 主窗口中,我收到消息“无法显示文件夹。这是 IMAP 存储的根目录。根目录不包含消息,但可能有子文件夹...”
  • 3) 如果我先选择我的垃圾邮件文件夹,单击 OutlookSpy 的文件夹按钮会生成一个“MAPIFolder”对话框。然后单击 Browse... 似乎只是生成了另一个对话框副本。两者都没有事件选项卡,它们只有属性、函数和脚本选项卡。
  • 点击文件夹按钮后,选择文件夹(注意复数)属性,然后点击浏览。
猜你喜欢
  • 1970-01-01
  • 2014-07-11
  • 1970-01-01
  • 2012-01-23
  • 1970-01-01
  • 1970-01-01
  • 2016-08-30
  • 1970-01-01
  • 2018-11-08
相关资源
最近更新 更多