博客
关于我
MSFT Outlook VBA处理新邮件的方法
阅读量:799 次
发布时间:2023-02-10

本文共 2455 字,大约阅读时间需要 8 分钟。

Outlook邮件自动转发处理脚本

背景与需求

在我们的工作环境中,使用了两种邮件客户端:外部邮箱(Outlook)和内部邮箱(Lotus Notes)。为了提高工作效率,我们希望在收到Outlook邮箱中的新邮件时,自动判断邮件的主题内容。如果邮件主题以“kkk:"开头,则将“kkk:"后面的内容提取出来,并将其作为收件人地址发送到Lotus Notes邮箱中。

解决方案

为了实现上述功能,我们可以使用微软Outlook的VBA宏编写一个自动化脚本。以下是实现该功能的详细代码和说明。

代码实现

Option Explicit
Public WithEvents outApp As Outlook.Application
Sub Initialize_handle()
Set outApp = Application
End Sub
' 打开OutLook的时候调用,注册application引用
Private Sub Application_Startup()
Initialize_handle
End Sub
' 收到新邮件的时候自动调用
Private Sub outApp_NewMailEx(ByVal EntryIDCollection As String)
Dim mai As Object
Dim intInitial As Integer
Dim intFinal As Integer
Dim strEntry As String
Dim intLength As Integer
intInitial = 1
intLength = Len(EntryIDCollection)
intFinal = InStr(intInitial, EntryIDCollection, ",")
Do While intFinal > 0
strEntryID = StringMid(EntryIDCollection, intInitial, (intFinal - intInitial))
Set mai = Application.Session.GetItemFromID(strEntryID)
newmail_proc mai
intInitial = intFinal + 1
intFinal = InStr(intInitial, EntryIDCollection, ",")
Loop
strEntryID = StringMid(EntryIDCollection, intInitial, (intLength - intInitial) + 1)
Set mai = Application.Session.GetItemFromID(strEntryID)
newmail_proc mai
End Sub
Private Sub newmail_proc(ByVal mai As Object)
Dim itm As Object
Dim result As Integer
Dim str_kkk As String
Dim str_subject As String
Dim len_subject As Integer
Dim str_body As String
Dim str_reception As String
str_subject = mai.subject
len_subject = Len(str_subject)
str_kkk = StringMid(str_subject, 1, 4)
result = StringStrComp(str_kkk, "kkk:", vbTextCompare)
If result > 0 Then
str_reception = StringMid(str_subject, 5, (len_subject - 4) + 1)
str_body = mai.body
Set itm = outApp.CreateItem(0)
With itm
subject = "新邮件来自a@a.com"
to = str_reception
body = str_body
send
End With
End If
End Sub

代码解释

  • 初始化设置:在Outlook启动时,注册一个引用,并初始化相关变量。
  • 新邮件处理:当收到新邮件时,通过NewMailEx事件处理,提取邮件的ID集合。
  • 邮件解析:解析每个邮件的ID,获取对应邮件对象进行处理。
  • 主题检查:检查邮件主题是否以“kkk:"开头。
  • 信息提取与转发:如果主题以“kkk:"开头,提取后续内容并转发到Lotus Notes邮箱。
  • 实施步骤

  • 打开Outlook,点击菜单栏的“工具” -> “宏” -> “安全性”,将宏的安全性设置为“低”。
  • 将以上代码粘贴到新的模块中,确保Option Explicit已设置。
  • 保存并关闭编辑器。
  • 注意事项

    • 代码中outApp引用需手动添加,确保在References中包含Outlook对象库。
    • 代码需放在正确的模块中,避免导致脚本无法运行。

    通过以上实现,我们可以自动处理Outlook收到的邮件,实现主题匹配后自动转发到Lotus Notes邮箱的功能,提升工作效率。

    转载地址:http://iaffk.baihongyu.com/

    你可能感兴趣的文章
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO三大组件基础知识
    查看>>
    NIO与零拷贝和AIO
    查看>>
    NIO同步网络编程
    查看>>
    NIO基于UDP协议的网络编程
    查看>>
    NIO笔记---上
    查看>>
    NIO蔚来 面试——IP地址你了解多少?
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NISP国家信息安全水平考试,收藏这一篇就够了
    查看>>
    NIS服务器的配置过程
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>
    NiuShop开源商城系统 SQL注入漏洞复现
    查看>>
    NI笔试——大数加法
    查看>>
    NLog 自定义字段 写入 oracle
    查看>>
    NLog类库使用探索——详解配置
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP 模型中的偏差和公平性检测
    查看>>
    Vue3.0 性能提升主要是通过哪几方面体现的?
    查看>>