Вы можете использовать метод GetConversation класса MailItem
, который получает объект Conversation , представляющий диалог, которому принадлежит этот элемент.
Возвращает GetConversationNull
(Nothing
в Visual Basic), если для элемента не существует диалога.Нет беседы для элемента в следующих сценариях:
- Элемент не был сохранен.Элемент может быть сохранен программно, действием пользователя или автосохранением.
- Для элемента, который можно отправить (например, элемент почты, элемент встречи или элемент контакта), элемент не имеетбыло отправлено.
- В реестре Windows отключены разговоры.
- Хранилище не поддерживает представление
Conversation
(например, Outlook работает в классическом онлайн-режиме с версией Microsoft Exchange).ранее, чем Microsoft Exchange Server 2010).Используйте свойство IsConversationEnabled объекта Store
, чтобы определить, поддерживает ли хранилище представление Conversation.
Следующий пример кода на C # (извините, я не знаком с python,но объектная модель Outlook является общей для всех языков программирования) предполагает, что выбранный элемент в окне проводника является почтовым элементом.Пример кода получает диалог, с которым связан выбранный почтовый элемент, и перечисляет каждый элемент в этом диалоге, отображая тему элемента.
void DemoConversation()
{
object selectedItem =
Application.ActiveExplorer().Selection[1];
// This example uses only
// MailItem. Other item types such as
// MeetingItem and PostItem can participate
// in the conversation.
if (selectedItem is Outlook.MailItem)
{
// Cast selectedItem to MailItem.
Outlook.MailItem mailItem =
selectedItem as Outlook.MailItem;
// Determine the store of the mail item.
Outlook.Folder folder = mailItem.Parent
as Outlook.Folder;
Outlook.Store store = folder.Store;
if (store.IsConversationEnabled == true)
{
// Obtain a Conversation object.
Outlook.Conversation conv =
mailItem.GetConversation();
// Check for null Conversation.
if (conv != null)
{
// Obtain Table that contains rows
// for each item in the conversation.
Outlook.Table table = conv.GetTable();
Debug.WriteLine("Conversation Items Count: " +
table.GetRowCount().ToString());
Debug.WriteLine("Conversation Items from Table:");
while (!table.EndOfTable)
{
Outlook.Row nextRow = table.GetNextRow();
Debug.WriteLine(nextRow["Subject"]
+ " Modified: "
+ nextRow["LastModificationTime"]);
}
Debug.WriteLine("Conversation Items from Root:");
// Obtain root items and enumerate the conversation.
Outlook.SimpleItems simpleItems
= conv.GetRootItems();
foreach (object item in simpleItems)
{
// In this example, enumerate only MailItem type.
// Other types such as PostItem or MeetingItem
// can appear in the conversation.
if (item is Outlook.MailItem)
{
Outlook.MailItem mail = item
as Outlook.MailItem;
Outlook.Folder inFolder =
mail.Parent as Outlook.Folder;
string msg = mail.Subject
+ " in folder " + inFolder.Name;
Debug.WriteLine(msg);
}
// Call EnumerateConversation
// to access child nodes of root items.
EnumerateConversation(item, conv);
}
}
}
}
}
void EnumerateConversation(object item,
Outlook.Conversation conversation)
{
Outlook.SimpleItems items =
conversation.GetChildren(item);
if (items.Count > 0)
{
foreach (object myItem in items)
{
// In this example, enumerate only MailItem type.
// Other types such as PostItem or MeetingItem
// can appear in the conversation.
if (myItem is Outlook.MailItem)
{
Outlook.MailItem mailItem =
myItem as Outlook.MailItem;
Outlook.Folder inFolder =
mailItem.Parent as Outlook.Folder;
string msg = mailItem.Subject
+ " in folder " + inFolder.Name;
Debug.WriteLine(msg);
}
// Continue recursion.
EnumerateConversation(myItem, conversation);
}
}
}