Súhrn
V tomto článku sa popisuje, ako používať objektovú knižnicu Microsoft Outlook 10.0 na načítanie konkrétnych správ pomocou metódy Hľadať a metódy Restrict v programe Microsoft Visual C#.
Ďalšie informácie
Ak chcete na načítanie konkrétnych Outlook použiť objektovú knižnicu Microsoft Outlook 10.0, postupujte takto:
-
Spustite Microsoft Visual Studio .NET alebo Microsoft Visual Studio 2005.
-
V ponuke Súbor ukážte na položku Nové a potom kliknite na položku Project.
-
V zozname Projekty Visual C# kliknite na položku Aplikácia konzoly. Predvolene sa vytvorí súbor Class1.cs.Poznámka V programe Microsoft Visual C# 2005 kliknite na položku Visual C#" v zozname Typy projektov jazyka Visual C #. Predvolene sa vytvorí súbor Program.cs.
-
Pridajte odkaz na objektovú knižnicu Microsoft Outlook 10.0. Postupujte takto:
-
V ponuke Project kliknite na položku Pridať odkaz.
-
Kliknite na kartu COM, vyhľadajte položku Objektová knižnica Outlook Microsoft 10.0 a potom kliknite na položku Vybrať. Poznámka: V Microsoft Visual C# 2005. na položku Vybrať nie je potrebné kliknúť.
-
V dialógovom okne Pridanie odkazov kliknite na tlačidlo OK.
-
Ak sa zobrazí výzva na generovanie obalov pre vybraté knižnice, kliknite na tlačidlo Áno.
-
-
V okne s kódom nahraďte kód nasledujúcimi príkladmi:
using System;using System.Reflection; // to use Missing.Valuenamespace FilterAppointments{ /// <summary> /// Summary description for Class1. /// </summary> class Class1 { /// <summary> /// The main entry point for the application. /// </summary> [STAThread] public static int Main(string[] args) { try { // Create an Outlook application. Outlook.Application oApp = new Outlook.Application(); // Get the Mapi NameSpace and the Logon. Outlook.NameSpace oNS = (Outlook.NameSpace)oApp.GetNamespace("mapi"); // Log on using dialog to choose a profile. oNS.Logon(Missing.Value, Missing.Value, true, true); // Alternate Logon using specific profile // TODO: Change the profile name where it is appropriate. //oNS.Logon("YourValidProfile", Missing.Value, false, true); // Get the Calendar folder. Outlook.MAPIFolder oCalendar = oNS.GetDefaultFolder(Outlook.OlDefaultFolders.olFolderCalendar); // Get the Items collection in the folder. Outlook.Items oItems = (Outlook.Items)oCalendar.Items; Console.WriteLine("Total Items (unrestricted): " + oItems.Count); //Include all occurrences of recurring items, and then sort them. oItems.Sort ("[Start]", false); oItems.IncludeRecurrences = true; // Define the string for the search criteria. String sCriteria; // Set the criteria for the Date fields. sCriteria = "[Start] <= '09/01/2002 08:00 AM' and [End] >= '2/15/2002 08:00 PM'"; // Set the criteria for a string field. // sCriteria = "[Subject] = 'Weekly recurring meeting'"; // Set the criteria for a numeric field. // Look for meetings that have not been responded to. // sCriteria = "[ResponseStatus] = " + (Int32)Outlook.OlResponseStatus.olResponseNotResponded) // Use the Restrict method to reduce the number of items to process. Outlook.Items oRestrictedItems = oItems.Restrict(sCriteria); oRestrictedItems.Sort ("[Start]", false); oRestrictedItems.IncludeRecurrences = true; Console.WriteLine("Total Items Unrestricted : " + oRestrictedItems.Count); Outlook.AppointmentItem oAppointment; //Get each item until item is null. Outlook.AppointmentItem oAppt; oAppt = (Outlook.AppointmentItem)oRestrictedItems.GetFirst(); while (oAppt != null) { // Console.WriteLine(i.ToString()); Console.WriteLine(" Subject: " + oAppt.Subject.ToString()); Console.WriteLine(" Start time: " + oAppt.Start.ToString()); Console.WriteLine(" End time: " + oAppt.End.ToString()); Console.WriteLine(" Occurrences: " + oAppt.RecurrenceState.ToString()); Console.WriteLine("\n\n"); oAppt = (Outlook.AppointmentItem)oRestrictedItems.GetNext(); } // Use the Find method to get single match. sCriteria = "[Start] >= '09/30/2001'"; Console.WriteLine("Criteria: " + sCriteria.ToString()); oAppointment = (Outlook.AppointmentItem)oItems.Find(sCriteria); Console.WriteLine("Used Find with Date fields"); if (oAppointment is Outlook.AppointmentItem) Console.WriteLine("Found -> " + oAppointment.Subject.ToString()); else Console.WriteLine("No object found"); // Log off oNS.Logoff(); // Clean up oAppointment = null; oRestrictedItems = null; oItems = null; oCalendar = null; oNS = null; oApp = null; } //Simple error handling catch (Exception e) { Console.WriteLine("{0} Exception caught.", e); } //Default return value return 0; } }}
-
Vyhľadajte v kóde textový reťazec TODO a potom upravte kód pre svoje prostredie.
-
Stlačením klávesu F5 vytvorte a spustite program.
Odkazy
Ďalšie informácie o funkciách zabezpečenia balíka Outlook 2002 nájdete po kliknutí na číslo článku databázy Microsoft Knowledge Base:
290500 Popis funkcií zabezpečenia e-mailu súvisiaceho s vývojármi v balíku Outlook 2002 Ďalšie informácie o problémoch, ktoré sa môžu vyskytnúť pri používaní vlastnosti Počet veľkých kolekcií, zobrazíte kliknutím na nasledujúce číslo článku vedomostnej databázy Microsoft Knowledge Base:
294385 OL2002: Vlastnosť Nesprávny počet pomocou opakovaných plánovaných činností