博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Outlook API
阅读量:6130 次
发布时间:2019-06-21

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

1、Outlook简介

若要从Outlook 外控制Outlook对象,必须在编写代码的工程中建立对Outlook对象库的引用。

1.1  Outlook Application说明:

代表整个Microsoft Outlook应用程序。它是层次结构中唯一可使用CreateObject方法或GetObject函数返回的对象。

1.2  Outlook Application 对象的用途:

  • 作为根对象,使用它可访问 Outlook 层次结构中的其他对象。
  • 允许直接访问使用CreateItem创建的新项目,而不用遍历对象层次结构。
  • 允许访问当前界面对象(浏览器和检查器)。

1.3  返回 Outlook Application 对象引用的方法:

  • 可以使用 CreateObject 函数启动新的Outlook 会话,并且返回Application对象的引用,该对象代表新会话
  • 可以使用GetObject函数返回Application对象的引用,该对象代表正在运行的会话。请注意,因为在任何给定时刻只能有一个Outlook实例处于运行状态,所以GetObject在Outlook中使用时无太大用途。CreateObject总是用来访问当前Outlook实例或在没有实例时创建新实例。但是,也可以使用GetObject方法的错误跟踪功能来确定Outlook当前是否处于运行状态
  • 可以在几种类型的语句中使用 New关键字隐式地创建Outlook Application对象的新实例,使用Set语句将对象变量设置为Application对象的新实例。也可以在Dim、Private、Public 或 Static语句中使用New关键字来声明对象变量。Application对象的新实例在第一次引用该变量时创建。

若要启动Outlook自动化会话,可以使用前期绑定或后期绑定。后期绑定使用GetObject或CreateObject函数初始化Outlook。例如,以下代码将对象变量设置为Outlook Application对象,该对象为Outlook对象模型中的最高层对象。所有自动化代码都必须首先定义Outlook Application对象,才能够访问其他Outlook对象。

Dim ol as Object/VariantSet ol = CreateObject("Outlook.Application")

若要使用前期绑定,首先要设置到Outlook对象库的引用。然后就可用以下语法启动Outlook会话。

Dim ol as Outlook.ApplicationSet ol = New Outlook.Application或直接使用:Dim ol as New Outlook.Application

大部分编程解决方案都与 Outlook 中存储的数据进行交互。Outlook在邮件应用程序编程接口(MAPI)文件夹中存储其全部信息。在将对象变量设置为Outlook Application对象后,通常要设置一个 Namespace对象来引用 MAPI,如下所示:

Set ol = New Outlook.ApplicationSet ns = ol.GetNameSpace("MAPI")Set f = ns.GetDefaultFolder(olFolderContacts)

 

2、访问Outlook

2.1  VBA包含3种从另一个程序中访问Outlook的方法。

2.1.1  Outlook未被加载:CreateObject方法

Sub GetOlObject_1()Dim ol As Object, counter As IntegerSet ol = CreateObject("Outlook.Application")counter = ol.Getnamespace("MAPI").Getdefaultfolder(6).Items.CountDebug.Print "InBox中邮件的总数为:"; counterEnd Sub

限制条件:CreateObject不能识别Outlook类型名称,只能识别Outlook常量。

例如:在VBA中,"收件箱"映射的类型名称是olFolderInbox,映射的Outlook常量是6。

counter = CreateObject("Outlook.Application").GetNamespace("MAPI").GetDefaultFolder(olFolderInbox).Items.Count

将返回一个错误。

2.1.2  Outlook已经被加载:GetObject方法

Sub GetOlObject_2()Dim ol As Object, counter As IntegerSet ol = GetObject(, "Outlook.Application")counter = ol.Getnamespace("MAPI").Getdefaultfolder(6).Items.CountDebug.Print "InBox中邮件的总数为:"; counterEnd Sub

 GetObject方法的限制条件同CreateObject。

2.1.3  加载Outlook_VBA_Library

References方法:无论Outlook是否被加载都独立。

手动引用:VBE-->工具-->引用-->Microsoft Outlook 11.0/12.0/15.0 Object Library 

Sub GetOlRef()ThisWorkbook.VBProject.References.AddFromFile "msoutl9.olb" 'Outlook 2000ThisWorkbook.VBProject.References.AddFromFile "msoutl10.olb" 'Outlook 2003ThisWorkbook.VBProject.References.AddFromFile "msoutl11.olb" 'Outlook 2007End Sub

 加载库后,你可以使用Outlook作为一个对象。

counter = Outlook.GetNamespace("MAPI").GetDefaultFolder(olFolderInbox).Items.Count

此种情况下,你可以使用Outlook的类型名称和常量。

Sub GetOlObject_3()Dim counter As Integercounter = Outlook.GetNamespace("MAPI").GetDefaultFolder(olFolderInbox).Items.CountDebug.Print "InBox中邮件的总数为:"; counterEnd Sub

 或者使用New关键字隐式地创建Outlook对象:

Sub GetOlObject_4()Dim ol As Outlook.Application, counter As IntegerSet ol = New Outlook.Applicationcounter = ol.GetNamespace("MAPI").GetDefaultFolder(6).Items.CountDebug.Print "3InBox中邮件的总数为:"; counterEnd Sub

 2.1.4  获取动态引用:

Sub GetRefInfo()Dim i As IntegerOn Error Resume NextFor i = 1 To ThisWorkbook.VBProject.References.Count    Debug.Print ThisWorkbook.VBProject.References.Item(i).Name    Debug.Print ThisWorkbook.VBProject.References.Item(i).Description    Debug.Print ThisWorkbook.VBProject.References.Item(i).GUID    Debug.Print ThisWorkbook.VBProject.References.Item(i).Major    Debug.Print ThisWorkbook.VBProject.References.Item(i).Minor    Debug.Print ThisWorkbook.VBProject.References.Item(i).FullPathNextEnd Sub

 

2.2  Outlook中的默认文件夹

2.2.1  DefaultFolder的清单

Sub ol_5()Dim ol As ObjectSet ol = CreateObject("Outlook.Application")With ol.GetNamespace("MAPI")Debug.Print .GetDefaultFolder(3).Name   '删除的项目Deleted itemsDebug.Print .GetDefaultFolder(4).Name   '发件箱PostOutDebug.Print .GetDefaultFolder(5).Name   '发送项目Sent itemsDebug.Print .GetDefaultFolder(6).Name   '收件箱PostInDebug.Print .GetDefaultFolder(9).Name   '日历CanlenderDebug.Print .GetDefaultFolder(10).Name  '联系人ContactsDebug.Print .GetDefaultFolder(11).Name  '日记JournalsDebug.Print .GetDefaultFolder(12).Name  '便签NotesDebug.Print .GetDefaultFolder(13).Name  '任务TasksDebug.Print .GetDefaultFolder(14).Name  '提醒RemindersDebug.Print .GetDefaultFolder(15).Name  '提醒RemindersDebug.Print .GetDefaultFolder(16).Name  '草稿DraftsEnd WithEnd Sub

 

OlDefaultFolders常量 Value
olFolderCalendar 9
olFolderContacts 10
olFolderDeletedItems 3
olFolderDrafts 16
olFolderInbox 6
olFolderJournal 11
olFolderJunk 23
olFolderNotes 12
olFolderOutbox 4
olFolderSentMail 5
olFolderTasks 13
olPublicFoldersAllPublicFolders 18
olFolderConflicts 19
olFolderLocalFailures 21
olFolderServerFailures 22
olFolderSyncIssues 20

 

2.3  Outlook的标准项目

Outlook标准的项目有以下几种:电子邮件(email)、约会(appointment)、联系人(contact)、任务(task)、日记(journal)、便签(note)、'sticker'(Post-it)、distributionlist

特殊项目:taskrequest、meetingrequest

Outlook根据存储的文件夹区分邮件:

草稿邮件:草稿文件夹-->GetDefaultFolder(16)

邮件:映射到PostOut-->GetDefaultFolder(4)

发送邮件:映射到Sent items-->GetDefaultFolder(5)

接收邮件:映射到PostIn-->GetDefaultFolder(6)

2.3.1  标准项目清单:

Sub ol_6()With CreateObject("Outlook.Application")    .CreateItem(0-7)End WithEnd Sub

 

OlItemType

value
olAppointmentItem 1
olContactItem 2
olDistributionListItem 7
olJournalItem 4
olMailItem 0
olNoteItem 5
olPostItem 6
olTaskItem 3

 

3  Outlook中的VBA命令

Email属性

 

转载于:https://www.cnblogs.com/yl153/p/6711519.html

你可能感兴趣的文章
jQuery(三)
查看>>
汇编--基础分析:数据段在内存中的存放及空间
查看>>
spring boot学习(6) SpringBoot 之事务管理
查看>>
峰Redis学习(4)Redis 数据结构(List的操作)
查看>>
jmeter二次开发
查看>>
写成/和/*的区别
查看>>
PHP上传遇到的问题-php 上传大文件主要涉及配置upload_max_filesize和post_max_size两个选项...
查看>>
项目Beta冲刺 用户试用报告
查看>>
Business Object Calculator Time Function
查看>>
Ubuntu 11.04 DHCP server 和 ipv6 备忘
查看>>
Eclipse设置软tab(用4个空格字符代替)及默认utf-8文件编码(unix)
查看>>
POJ3668 Game of Lines
查看>>
[NOIP2003] 提高组 洛谷P1040 加分二叉树
查看>>
Codeforces Round #389 Div.2 B. Santa Claus and Keyboard Check
查看>>
Java基础—异常
查看>>
1-3-1中间固定两边变化
查看>>
.Net 得到星期 和 天气预报
查看>>
经典计算机算法设计方法(2) -- 回溯法
查看>>
radio选择
查看>>
JS中关于clientWidth offsetWidth scrollWidth 等的含义
查看>>