Я подключен к серверу обмена, поэтому некоторые письма хранятся в моем локальном файле Outlook, а некоторые - на сервере. В Outlook количество элементов в папке (которую я хочу прочитать) показывает 13 000 элементов. Но когда я пытаюсь перебрать элементы через VBA:
Sub asdf()
Dim objOutlook As Outlook.Application
Set objOutlook = CreateObject("Outlook.Application")
Dim objMAPIFolder As Object
Dim objFolder As Object
Dim myItem As Outlook.MailItem
Dim archivFolder As Outlook.Folder
Dim subFolder As Outlook.Folder
For Each objMAPIFolder In objOutlook.Session.Folders
For Each objFolder In objMAPIFolder.Folders
If objFolder.Name = "Inbox" Then
Set archivFolder = objFolder
For Each subFolder In archivFolder.Folders
If subFolder.Name = "Folder X" Then
MsgBox subFolder.Items.Count 'should be 13.000 but says 5.000
End If
Next
End If
Next
Next
Set objOutlook = Nothing
End Sub
Это показывает мне счет 5.000. В Outlook я могу щелкнуть «Щелкните здесь, чтобы просмотреть дополнительные сведения о Microsoft Exchange» и просмотреть остальные сообщения.
Как я могу перебирать серверную почту через VBA?
С Уважением Wolle
На уровне расширенного MAPI (C++ или Delphi) вы можете открыть папку в онлайн-режиме для доступа к удаленно сохраненным сообщениям.
В случае VBA (или других языков, таких как C# или VB.Net) и если использование Выкуп является вариантом, он может открыть папку в онлайн-режиме (его метод RDOSession.GetFolderFromID
позволяет передать флаг MAPI_NO_CACHE
):
MAPI_NO_CACHE = &H200
MAPI_BEST_ACCESS = &H10
set Session = CreateObject("Redemption.RDOSession")
Session.MAPIOBJECT = objOutlook.Session.MAPIOBJECT
...
set rFolder = Session.GetFolderFromID(subFolder.EntryID, , MAPI_NO_CACHE + MAPI_BEST_ACCESS)
MsgBox rFolder.Items.Count