Outlook API在c#中获取会议详细信息

时间:2015-03-31 11:08:18

标签: c# outlook

我正在尝试使用c#windows app为Outlook创建API。为此,要获取所有AppointmentItem,我使用下面的代码,它正在工作。

Microsoft.Office.Interop.Outlook.Application oApp = null;
            Microsoft.Office.Interop.Outlook.NameSpace mapiNamespace = null;
            Microsoft.Office.Interop.Outlook.MAPIFolder CalendarFolder = null;
            Microsoft.Office.Interop.Outlook.MAPIFolder Inbox = null;
            Microsoft.Office.Interop.Outlook.Items outlookCalendarItems = null;

            oApp = new Microsoft.Office.Interop.Outlook.Application();
            mapiNamespace = oApp.GetNamespace("MAPI"); ;
            mapiNamespace.Logon("", "",true, true);
            CalendarFolder = mapiNamespace.GetDefaultFolder(Microsoft.Office.Interop.Outlook.OlDefaultFolders.olFolderCalendar);
            CalendarFolder = oApp.Session.GetDefaultFolder(Microsoft.Office.Interop.Outlook.OlDefaultFolders.olFolderCalendar);
            DateTime startTime = DateTime.Now;
            DateTime endTime = startTime.AddDays(5);
            //string filter = "[Start] >= '"  + startTime.ToString("g")  + "' AND [End] <= '" + endTime.ToString("g") + "'";
            outlookCalendarItems = CalendarFolder.Items;
           // outlookCalendarItems.Restrict(filter);
           // outlookCalendarItems.Sort("Start");
            outlookCalendarItems.IncludeRecurrences = true;

            int i = 0;
            foreach (Microsoft.Office.Interop.Outlook.AppointmentItem item in outlookCalendarItems)
            {

                dataGridCalander.Rows.Add();
                dataGridCalander.Rows[i].Cells[0].Value = i + 1;

                if (item.Subject != null)
                {
                    dataGridCalander.Rows[i].Cells[1].Value = item.Subject;
                } 
}

类似地,我希望获得在特定会议室的展望和状态中创建的可用会议室(可用或不可用)。在此先感谢。

1 个答案:

答案 0 :(得分:0)

我注意到以下代码行:

 foreach (Microsoft.Office.Interop.Outlook.AppointmentItem item in outlookCalendarItems)

不要遍历循环中的所有Outlook项目。使用Find / FindNext或Restrict方法查找所需的子集。

或者使用Folder类的GetTable方法获取包含Filter过滤的项的Table对象。如果Filter是空字符串或省略Filter参数,则GetTable返回一个表,其中的行表示文件夹中的所有项。如果Filter是空字符串或者省略Filter参数并且TableContents是olHiddenItems,则GetTable返回一个表,其中的行表示文件夹中的所有隐藏项。

Sub DemoTable()  
  'Declarations  
  Dim Filter As String  
  Dim oRow As Outlook.Row  
  Dim oTable As Outlook.Table  
  Dim oFolder As Outlook.Folder  

  'Get a Folder object for the Inbox  
  Set oFolder = Application.Session.GetDefaultFolder(olFolderInbox)  

  'Define Filter to obtain items last modified after May 1, 2005  
   Filter = "[LastModificationTime] > '5/1/2005'"  
  'Restrict with Filter  
   Set oTable = oFolder.GetTable(Filter)  

  'Enumerate the table using test for EndOfTable  
   Do Until (oTable.EndOfTable)  
     Set oRow = oTable.GetNextRow()  
     Debug.Print (oRow("Subject"))  
     Debug.Print (oRow("LastModificationTime"))  
   Loop  
 End Sub

Outlook对象模型不为房间提供任何方法或属性。您可以使用Namespace类的OpenSharedFolder方法打开房间的共享日历。

请考虑使用EWS。有关详细信息,请参阅EWS Managed API, EWS, and web services in Exchange