Inhalt
OLKeeper | |
Der OLKeeper verhindert zuverlässig, dass Sie Microsoft Outlook unbeabsichtigt schlieÃen und so etwa wichtige Emails verpassen würden. |
Um z.B. den Inhalt der Spam-Ordners zu löschen, gibt es im Kontextmenü einen Befehl. Für die meisten anderen Ordner gibt es den Befehl aber nicht. Dieses Beispiel ersetzt diesen fehlenden Befehl und löscht den kompletten Inhalt des gerade aktuellen Ordners. Es gibt einen besonderen Hinweis, wenn es sich bei dem Ordner um einen Suchordner handelt. Suchordner sind nur Ansichten auf Ordner und können die Inhalte des ganzen Postfaches anzeigen. In diesem Fall ist das Löschen ist den meisten Fällen wohl nicht gewünscht.
Ziehen Sie sich einfach eine Schaltfläche auf die Symbolleiste, und Sie haben die Funktion 'Ordner leeren' für jeden beliebigen Ordner.
(Dieses Makro funktioniert erst ab Outlook 2007.)
Für IMAP-Ordner haben wir hier noch ein Beispiel: IMAP-Nachrichten löschen
Public Sub EmptyFolder() Dim Folder As Outlook.Folder Dim FolderDeleted As Outlook.Folder Dim Store As Outlook.Store Dim Items As Outlook.Items Dim Item As Object Dim Pa As Outlook.PropertyAccessor Dim i As Long, Count As Long Dim Delete As Boolean, IsSearchFolder As Boolean Dim Msg As String Set Folder = Application.ActiveExplorer.CurrentFolder Set Items = Folder.Items Count = Items.Count If Count = 0 Then Exit Sub Set Pa = Folder.PropertyAccessor IsSearchFolder = (Pa.GetProperty("http://schemas.microsoft.com/mapi/proptag/0x36010003") = 2) If IsSearchFolder Then Msg = "Wirklich " & Count & " Elemente aus einem Suchordner löschen?" If MsgBox(Msg, vbQuestion Or vbYesNoCancel Or vbDefaultButton2) <> vbYes Then Exit Sub Else Msg = Count & " Elemente löschen?" If MsgBox(Msg, vbQuestion Or vbYesNoCancel) <> vbYes Then Exit Sub End If Set Store = Folder.Store Set FolderDeleted = Store.GetDefaultFolder(olFolderDeletedItems) Delete = (Folder.EntryID = FolderDeleted.EntryID) If Delete Then For i = Count To 1 Step -1 Items(i).Delete Next Else For i = Count To 1 Step -1 Set Item = Items(i) Item.UnRead = False Item.Save Item.Move FolderDeleted Next End If End Sub
Category-Manager | |
Mit dem Category-Manager können Sie Outlook Kategorien gruppieren, synchronisieren und filtern, neuen Emails automatisch die Kategorie des Absenders zuweisen und vieles mehr. Das Addin ist auch für IMAP geeignet. |
Dieser Code macht das gleiche wie oben, nur dass nicht der ganze Ordnerinhalt gelöscht wird, sondern nur die ausgewählten Elemente.
Public Sub EmptySelection() Dim Folder As Outlook.Folder Dim FolderDeleted As Outlook.Folder Dim Store As Outlook.Store Dim Item As Object Dim Selection As Outlook.Selection Dim Pa As Outlook.PropertyAccessor Dim i As Long, Count As Long Dim Delete As Boolean, IsSearchFolder As Boolean Dim Msg As String Set Folder = Application.ActiveExplorer.CurrentFolder Set Selection = Application.ActiveExplorer.Selection Count = Selection.Count If Count = 0 Then Exit Sub Set Pa = Folder.PropertyAccessor IsSearchFolder = (Pa.GetProperty("http://schemas.microsoft.com/mapi/proptag/0x36010003") = 2) If IsSearchFolder Then Msg = "Wirklich " & Count & " Elemente aus einem Suchordner löschen?" If MsgBox(Msg, vbQuestion Or vbYesNoCancel Or vbDefaultButton2) <> vbYes Then Exit Sub Else Msg = Count & " Elemente löschen?" If MsgBox(Msg, vbQuestion Or vbYesNoCancel) <> vbYes Then Exit Sub End If Set Store = Folder.Store Set FolderDeleted = Store.GetDefaultFolder(olFolderDeletedItems) Delete = (Folder.EntryID = FolderDeleted.EntryID) If Delete Then For i = Selection.Count To 1 Step -1 Set Item = Selection(1) Item.Delete Next Else For i = Selection.Count To 1 Step -1 Set Item = Selection(i) Item.UnRead = False Item.Save Item.Move FolderDeleted Next End If End Sub
SAM | |
Legen Sie fest, mit welcher "Identität" Ihre Emails beim Empfänger erscheinen sollen. Mit SAM bestimmen Sie den Absender und Speicherort für Emails anhand von Regeln. |
Dieses einfache Beispiel prüft nicht, ob es sich beim Ordner um einen Suchordner handelt und funktioniert auch für Outlook 2003 und älter.
Public Sub EmptyFolder() Dim Folder As Outlook.MAPIFolder Dim Items As Outlook.Items Dim Msg As String Dim i As Long Set Folder = Application.ActiveExplorer.CurrentFolder Set Items = Folder.Items Msg = Items.Count & " Element(e) aus " & Folder.Name & " löschen?" If MsgBox(Msg, vbYesNo) = vbYes Then For i = Items.Count To 1 Step -1 Items.Remove i Next End If End Sub
OLKeeper | |
Der OLKeeper verhindert zuverlässig, dass Sie Microsoft Outlook unbeabsichtigt schlieÃen und so etwa wichtige Emails verpassen würden. |