![]() |
Termineintrag aus Outlook auslesen
Hallo,
ich möchte von meinem Programm aus auf Outlook zugreifen und dort alle Termin für den heutigen Tag jeweils auslesen. An jedem Termineintrag ist eine Datei angehängt, an die müsste ich auch kommen. Wie ich einen Eintrag in Outlook erzeugen kann weiss ich, aber wie kann ich ihn wieder auslesen? |
Re: Termineintrag aus Outlook auslesen
Hallo Susanne,
ich bin mir nicht sicher, ob ich Dir bei den Sachen mit dem Anhang weiterhelfen kann, aber generell ist das Auslesen von FolderItems unter Outlook immer die gleichen Strickart. Ich hab' das Beispiel aus dem Swiss Delphi Center zum Thema ![]()
Delphi-Quellcode:
Ich hoffe, das hilft Dir ein wenig weiter, auch wenn ich's nicht testen konnte...
uses ComObj;
procedure TForm1.Button1Click(Sender: TObject); const olFolderCalendar = $00000009; var outlook, NameSpace, Termine, Termin: OleVariant; i: Integer; begin outlook := CreateOleObject('Outlook.Application'); NameSpace := outlook.GetNameSpace('MAPI'); Termine := NameSpace.GetDefaultFolder(olFolderCalendar); for i := 1 to Termine.Items.Count do begin Termin := Termine.Items.Item(i); // Titel des Termins und Startdatum mit Zeit auslesen: ShowMessage(Termin.Subject + '<Begin: ' + DateTimeToStr (Termin.Start) + ' >'); end; Outlook := UnAssigned; end; { gefundene Item-Properties: Subject (alphanumerisch) Body (alphanumerisch) Start (Datum/Uhrzeit) Duration (numerisch) End (Datum/Uhrzeit) Location (alphanumerisch) ReminderMinutesBeforeStart (Integer) ReminderSet (boole'sch) Categories (alphanumerisch) BusyStatus (numerisch) (olFree = frei), olTentative = unter Vorbehalt), olBusy = gebucht), olOutOfOffice = abwesend)) Categories (alphanumerisch) CreationTime (alphanumerisch) ReminderPlaySound (boole'sch) } |
Re: Termineintrag aus Outlook auslesen
es hat geholfen, auf dem richtigen Weg war ich dann doch schon so langsam. Ich hab da noch etwa gefunden wie 'Filter setzen'
TerminItem:= Termine.Items.Restrict('[START] = ''05.08.2004'''); Aber irgendwie bekomme ich dann nur noch null ergebnisse und wenn ich das bisherige lasse, dann zeigt er mir jeden Eintrag an, auch die vom nächsten tag und ich möchte nur die vom heutigen Tag. |
Re: Termineintrag aus Outlook auslesen
Also: In VB machen die das wie folgt (hab's mal nach Object Pascal umgesetzt - ähnelt Deinem Ansatz):
Delphi-Quellcode:
Mit dem Datumsformat bin ich mir nicht so ganz sicher. Lass Dir doch zum Test mal einen Propertywert von "Start" anzeigen, um zu sehen, wie das Datum angegeben werden muss. Auf jeden Fall aber würd' ich den Filterwert mal in einfach Hochkommas setzen.
// benötigte zusätzliche Variable (Resultset für die
// Filterung Var GefilterteTermine: OleVariant; // Filter setzen: ergibt [Start] = '05.08.2004' // (Suchstring haben die in einfache Hochkommas // gesetzt...) sFilter := '[Start] = ''05.08.2004'''; // und dann die Filterfunktion auf das zu filternde // Termin-Resultset anwenden (hast Du ja entsprechend // umgesetzt - müsste laufen) GefilterteTermine := Termine.Items.Restrict(sFilter); // Anschließend müssten in GefilterteTermine die // gewünschten Dates drin stehen: Termin := GefilterteTermine.Items.Item(i); Wie schon vorher: Konnte leider nichts Testen. Ich verlass mich da mal blind auf die VB-Cracks ... :stupid: |
Re: Termineintrag aus Outlook auslesen
nee, funktioniert nicht, an folgender Stelle bekomme ich dann eine Fehlermeldung, dass das Automatisierungsobject die Funktion Items nciht unterstützt.
Zitat:
|
Re: Termineintrag aus Outlook auslesen
Guten Morgen!
Ich hab's mir nochmal angesehen. Vielleicht ist hier das "Items" zu viel und es müsste statt
Delphi-Quellcode:
so heißen:
Termin := GefilterteTermine.Items.Item(i);
Delphi-Quellcode:
weil das Ergebnis von "Restrict()" ein Items-Objekt zurückgibt ??? *mutmaß* GefilterteTermine ist ja ein OLEVariant und man bekommt nicht direkt mit, welcher Objekttyp "drinsteckt".
Termin := GefilterteTermine.Item(i);
Probier's bitte mal aus. Ansonsten muss ich mir wirklich mal ein System mit Outlook vornehmen und die Sache mal ausprobieren (kann aber etwas dauern). Das Ganze Interessiert mich jetzt nämlich selber und ich hasse Trockenschwimmen! |
Re: Termineintrag aus Outlook auslesen
stimmt, das items war zu viel!
jetzt versuche ich immernoch, an den blöden Anhang des Termins zu kommen. ich habe jetzt einfach nur mal versucht, herauszubekommen, wieviel Anhänge er denn findet: Am Ende möchte ich dann den Pfad mit Dateinamen haben, ich hatte es auch schon versucht mit SaveToFile, aber da sagte er dann, dass die MEthode nicht unterstützt wird.
Code:
Fehlermeldung: eVariantTypeCastError: Variante des Typs Dispatch konnte nicht in Typ Integer konvertiert werden.
for i := 1 to gefilterteTermine.Count do
begin Termin := GefilterteTermine.Item(i); //Titel des Termins und Startdatum mit Zeit auslesen: ShowMessage(Termin.Subject + ' '+ DateToStr(Termin.Start) ); //Anhang extrahieren oder den Pfad + Datei x := Termin.Attachments; end; Was muss ich denn nun machen? |
Re: Termineintrag aus Outlook auslesen
Hallo mal wieder...
Du müsstest eigentlich für ein Attachment-Objekt wieder eine Variable vom Typ OLEVariant deklarieren und dann, so wie Du schon richtig vermutet hast, diesem das gewünschte Attachment zuweisen. Das würde dan so aussehen (Portiert aus VB):
Delphi-Quellcode:
Der Zugriff auf das erste Attachment über die Angabe eines Index(!) -> gibt bestimmt Probleme, wenn der Termin keine Attachments hat, also vielleicht vorher über Termin.Attachments.Count erst die Anzahl prüfen...
Var Anhang: OLEVariant;
Delphi-Quellcode:
Jetzt müssten in Anhang die Daten des ersten Attachments stehen und Du müsstest so auf den FileName zugreifen können. Einen Pfadnamen gibt's hier denke ich nicht.
Anhang := Termin.Attachments(1);
Delphi-Quellcode:
Speichern kannst Du den Anhang (z. B. in "C:\Temp") wie folgt:
sFileName := Anhang.FileName;
Delphi-Quellcode:
Ich hab' noch eine wunderbare Modelldoku (von MS) gefunden:
sFileName := 'C:\Temp\' + sFileName;
Anhang.SaveAsFile (sFileName); ![]() Hier noch ein Link (ist zwar alles VB/VBA aber die Umsetzung dürfte nicht sooo schwer sein :zwinker: ): ![]() Auf dieser Seite kannst Du auch 'mal stöbern: ![]() Ich hoffe, das Alles hilft Dir weiter ... |
Re: Termineintrag aus Outlook auslesen
Zitat:
|
Re: Termineintrag aus Outlook auslesen
Hi!
Probier das mal:
Delphi-Quellcode:
Wenn's klappt bin ich zufrieden :-D . Ansonsten muss ich hier meine Waffen strecken. Sorry. :(
Anhang := Termin.Attachments.Item(1);
|
Re: Termineintrag aus Outlook auslesen
vielen vielen Dank!!! Es klappt!!! Lass dich knutschen! :dancer:
|
Re: Termineintrag aus Outlook auslesen
:mrgreen:
|
Re: Termineintrag aus Outlook auslesen
langsam werde ich dann doch noch wahnsinnig, mein Filter will nicht mehr! Ich habe in Outlook gestern einen Termin und für heute drei Termine drin. Er findet alle vier, aber wenn der Filter drauf war, hat er null. Ich weiss nicht was ich getan habe, es funktionierte schon so wunderbar.
Code:
an der Zeile: GefilterteTermine := oItems.Restrict(sFilter);
function TfrmWiedervorlage.TerminAbfragen(datum:String):Boolean;
var i : Integer; Termine, Termin : OleVariant; oItems, x : OleVariant; GefilterteTermine : OleVariant; sFilter, sFileName : String; begin try Outlook:= CreateOleObject('Outlook.Application'); NmSpace:= Outlook.GetNamespace('MAPI'); NmSpace.Logon(EmptyParam, EmptyParam, False, True); Termine:= NmSpace.GetDefaultFolder(olFolderCalendar); oItems := Termine.Items; //Filter setzen: heutige Datum GefilterteTermine := oItems.Restrict(sFilter); i:= oItems.count //hier hat er die vier Termine drin i:= GefilterteTermine.count; //hier sind es dann nur noch 0 ???? for i := 1 to gefilterteTermine.Count do begin Termin := GefilterteTermine.Item(i); ShowMessage(Termin.Subject + ' '+ DateToStr(Termin.Start) ); x:= Termin.Attachments.Item(1); sFileName:= x.FileName; sFileName:= 'C:\'+sFileName; x.SaveAsFile(sFileName); DateiAuslesen(sFileName); //Datei am Ende loeschen DeleteFile(pChar(sFileName)); end; Result:= True; except ShowMessage('Fehler in Funktion TerminAbfragen'); Result:= false; end; NmSpace.Logoff; Termin:=Unassigned; x:=Unassigned; GefilterteTermine:= Unassigned; Termine:= Unassigned; Outlook:= Unassigned; end; scheint es zu scheitern, denn wenn ich statt datum Subject abfrage geht er auch in die Schleife rein. |
Re: Termineintrag aus Outlook auslesen
Hi Susanne!
Wo wird denn "sFilter" gesetzt? Wenn Dein Filter String nicht initialisiert/belegt wird, dann geht's glaube ich in die Hose, weil nichts gescheites drin steht... |
Re: Termineintrag aus Outlook auslesen
Delphi-Quellcode:
so habe ich den Filter gesetzt, ist irgendwie nicht mitgekommen
sFilter := '[Start] ='''+ DateToStr(Date) +'''';
Delphi-Quellcode:
damit z.B. zeigt er mir den Termin an, was ist also bei der anderen Zeile falsch?
sFilter := '[Subject] ='''+ 'Sport' +'''';
|
Re: Termineintrag aus Outlook auslesen
Guten Morgen,
ein Stückchen weiter oben hatte ich kurz erwähnt, dass ich mir wegen des Datumsformats für "Start" im Filter-String nicht sicher bin. Es könnte sein, dass das Dein Problem ist. Lass' Dir doch einfach mal den Property-Wert von "Start" ausgeben und sieh mal nach, wie das Datum formatiert ist. Etwas anderes fällt mir momentan nicht ein. Viel Glück! |
Re: Termineintrag aus Outlook auslesen
ich verstehe es einfach nicht. Es hat den ganzen morgen über geklappt (mal wieder) und jetzt wieder nicht mehr richtig. Das mit dem Datum ist richtig. Also: Montags 3 TErmine Dienstag einer
Code:
damit ist im Moment das Ergebnis 1, er zeigt mir den ersten Eintrag für Montag an, es sind aber nun mal drei und er müsste mir alle drei anzeigen, wie er es ja bisher gemacht hat.
sFilter := '[START] ='''+ dateToStr(date) +'''';
Code:
damit ist das Ergebnis 4, er zeigt mir zuerst den Dienstag an (warum eigentlich?) und anschliessend alle drei am Montag.
sFilter := '[START] >='''+ dateToStr(date) +'''';
Ich versteh es einfach nicht! IRgendwer irgendeine Idee, was hier passiert? Da hat meine Logik irgendwo einen Knick. |
Re: Termineintrag aus Outlook auslesen
zu deinem Zeitproblem,
vielleicht braucht [Start] kein Datum sondern ein DatumZeit [Start] >= 1.1.2004 08:00:00 [Start] <= 1.1.2004 23:59:59 nicht getestet nur ne Vermutung Nachdem ich das Beispiel bei mir zum Laufen gebracht habe, stellte ich fest, dass zwar die Termine kommen, aber keine eingeplanten Daueraufträge als Termin mit angezeigt werden. (z.B. zeige Tag um 10:15 Uhr eine Meldung an) Danach habe ich die Zeile
Delphi-Quellcode:
auf
Termine := NameSpace.GetDefaultFolder(olFolderCalendar); // olFolderCalendar = 9
Delphi-Quellcode:
abgeändert.
Termine := NameSpace.GetDefaultFolder(olFolderTasks ); // olFolderTasks = 13
nun bekomme ich zwar die Aufgaben, aber die Zeitinformation kann nicht ermittelt werden. Gibt es eine andere Möglichkeit die Termine und Aufgaben eines Tages gemeinsam aufzulisten? |
Re: Termineintrag aus Outlook auslesen
Hallo!
Soweit ist ja alles ganz gut beschrieben, nur leider liefert die o.g. Filterklausel [Start] = "05.08.2004" keinerlei Ergebnisse. Das gleiche Problem hatte Susanne ja AFAIK auch. Ich habs auch mit einfachen doppelten Gänsefüsschne probiert [Start] = ''05.08.2004'' hilft genauso wenig... keinerlei Ergebnisse. So klappt das Auslesen wunderbar, nur sind das halt ein paar Termine auf einmal :) Jemand einen Vorschlag? tyler |
Re: Termineintrag aus Outlook auslesen
Hallo Domo Sokrat,
Danke für das Programm, es funktioniert bei mir gut. Leider aber bekomme ich nur meine eigenen Termine zu gesicht. Wie kann ich auch die fremden Termine vom Exchange Server holen? Die Kollegin hatte mir sogar extra schreibrechte auf Ihren Kalender gegeben, ich seh trotzdem nur meine Termine. Hast du oder jemand anders eine Lösung? Gruß GÜnter Hanke |
Re: Termineintrag aus Outlook auslesen
Hi,
ich bin beim stöbern auf diesen Thread gekommen und habe das gleich mal ausprobiert:
Delphi-Quellcode:
Jetzt werden in meinem Memo schön die Termine mit Beschreibung etc angeziegt. Ist ne super Sache, allerdings verstehe ich einige Passagen des Quellcodes nicht. Ich will den ja nicht nur einfach kopieren, sondern auch verstehen. Wäre jmd bereit mir das zu erleutern?
procedure TForm1.Button1Click(Sender: TObject);
const olFolderCalendar = $00000009; var outlook, NameSpace, Termine, Termin: OleVariant; i: Integer; begin outlook := CreateOleObject('Outlook.Application'); NameSpace := outlook.GetNameSpace('MAPI'); Termine := NameSpace.GetDefaultFolder(olFolderCalendar); for i := 1 to Termine.Items.Count do begin Termin := Termine.Items.Item(i); // Titel des Termins und Startdatum mit Zeit auslesen: memo1.lines.add(DateTimeToStr (Termin.Start) + ' bis ' + DateTimeToStr (Termin.End)+ ': ' + Termin.Subject + ', ' + Termin.Location + ', ' + Termin.Body ); end; Outlook := UnAssigned; end; Zum Beispiel stellt sich mir die Frage, warum brauche ich eine Constante und was macht die? Dann verstehe ich die nächsten Zeilen, aber schon die Zeile
Delphi-Quellcode:
hab ich wieder Probleme. Der Rest ist wieder relativ klar, allerdings verstehe ich nicht, warum ich einfach Termin.X schreiben kann um irgendwas x-beliebiges auslesen kann. Termin ist doch eindeutig zugewiesen, warum hat das noch die ganzen Unterpunkte??
NameSpace := outlook.GetNameSpace('MAPI');
Hoffe, mir kann jmd helfen, und sorry für die vll blöden Fragen... bye |
AW: Re: Termineintrag aus Outlook auslesen
Zitat:
ich habe diesen Code auch mal ausprobiert. Funktioniert super. Wie aber kann ich auf einen anderen (fremden) freigegebenen Kalender zugreifen und Termine exportieren. :?: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz