Live-Forum - Die aktuellen Beiträge
Anzeige
Archiv - Navigation
1192to1196
Aktuelles Verzeichnis
Verzeichnis Index
Übersicht Verzeichnisse
Vorheriger Thread
Rückwärts Blättern
Nächster Thread
Vorwärts blättern
Anzeige
HERBERS
Excel-Forum (Archiv)
20+ Jahre Excel-Kompetenz: Von Anwendern, für Anwender
Inhaltsverzeichnis

Outlook-Excel-Outlook

Outlook-Excel-Outlook
Thomas
Einen schönen Abend zusammen,
ich hab zwei Codes gefunden und angepasst soweit ich konnte aber nun hänge ich bzw. bin mit meinem Wissen am Ende.
Mit dem Einlesen der Outlookkontakte in Excel das funzt soweit bis auf die Formatierung der Telefonnummern gleich im Code. Das zum einen.
Der andere Code schreibt mir die Excelkontakte wieder zurück.
Erstens der Code bringt eine Fehlermeldung bei dem zurückschreiben der Telefon und Mobil Nummer. ( Objekt unterstützt Eigenschaft und Methode nicht.
Zweitens sollte der Code die Kontakte in Outlook erst löschen bevor die neue Kontakte übergeben werden, da ich sonst doppelte einträge habe.
Code zum Einlesen in Excel
~

Sub ContactsToExcel()
'Deklaration
Dim oApp As New Outlook.Application
Dim nspMapi As Outlook.Namespace
Dim folMapi As Outlook.MAPIFolder
Dim itmAll As Outlook.Items
Dim itmReal As Outlook.Items
Dim itmContacts As Outlook.ContactItem
Dim strContactFilter As String
Dim excApp As Object
Dim excWkb As Object
Dim excWks As Object
Dim intRow As Integer
'Outlook-Objekte öffnen
Set nspMapi = oApp.GetNamespace("MAPI")
Set folMapi = nspMapi.GetDefaultFolder(olFolderContacts)
Set itmAll = folMapi.Items
'Verteilerlisten herausfiltern,
'nur 'Richtige Kontakte' verwenden
strContactFilter = "[MessageClass] = 'IPM.Contact'"
Set itmReal = itmAll.Restrict(strContactFilter)
'Excel-Objekte öffnen
Set excApp = Excel.Application
Set excWkb = excApp.ThisWorkbook           'Neues Workbook anlegen
Set excWks = excWkb.Sheets(1)                  'Erstes Sheet
'Excel-Worksheet aufbereiten
With excWks
'Sheet-Name
.Name = "Kontakte"
'Spaltenüberschriften
.Cells(1, 1).Value = "Vorname"
.Cells(1, 2).Value = "Nachname"
.Cells(1, 3).Value = "Strasse"
.Cells(1, 4).Value = "PLZ"
.Cells(1, 5).Value = "Ort"
.Cells(1, 6).Value = "Telefon"
.Cells(1, 7).Value = "Mobil"
.Cells(1, 8).Value = "eMail"
.Cells(1, 9).Value = "Fax"
.Cells(1, 10).Value = "Tel. geschäftl."
.Cells(1, 11).Value = "Fax geschäftl."
'Spaltenüberschriften fett
.Rows("1:1").Font.Bold = True
'Outlook-Kontakte nach Excel übertragen
intRow = 2
For Each itmContacts In itmReal
.Cells(intRow, 1).Value = itmContacts.FirstName
.Cells(intRow, 2).Value = itmContacts.LastName
.Cells(intRow, 3).Value = itmContacts.HomeAddressStreet
.Cells(intRow, 4).Value = itmContacts.HomeAddressPostalCode
.Cells(intRow, 5).Value = itmContacts.HomeAddressCity
.Cells(intRow, 6).Value = itmContacts.HomeTelephoneNumber    'Formatierung
.Cells(intRow, 7).Value = itmContacts.MobileTelephoneNumber    'Formatierung
.Cells(intRow, 8).Value = itmContacts.Email1Address
.Cells(intRow, 9).Value = itmContacts.HomeFaxNumber   'Formatierung
.Cells(intRow, 10).Value = itmContacts.BusinessTelephoneNumber  'Formatierung
.Cells(intRow, 11).Value = itmContacts.BusinessFaxNumber    'Formatierung
intRow = intRow + 1
Next itmContacts
'Optimale Spaltenbreite
.Columns.AutoFit
End With
'Excel einblenden
excApp.Visible = True
'Speicher freigeben
Set itmReal = Nothing
Set itmAll = Nothing
Set folMapi = Nothing
Set nspMapi = Nothing
Set excWks = Nothing
Set excWkb = Nothing
Set excApp = Nothing
End Sub
~
Code zum zurück nach Outlook Schreiben
~

Sub Send_Contact_List()
Dim qWks As Worksheet, i As Integer
Dim MyOutApp As Object, MyOutCon As Object
'Wo stehen die Kontaktdaten
Set qWks = Worksheets("Kontakte")
'Outlook Objekt erstellen
Set MyOutApp = CreateObject("Outlook.Application")
'Mit "With" wird auf das Tabellenobjekt referenziert
With qWks
'Zählschleife starten
'Dazu wird der letzten Eintrag in Spalte A bestimmt
'Der Adressenbereich beginn in Zeile 2
'deshalb startet auch die Zählschleife dort
For i = 2 To Range("A65536").End(xlUp).Row
'Outlook Kontaktobject erstellen
Set MyOutCon = MyOutApp.CreateItem(2)
'Eine vollständige Liste der möglichen Felder
'finden Sie in der Outlook-VBA-Hilfe
With MyOutCon
.FirstName = Cells(i, 1).Value   'Name
.LastName = Cells(i, 1).Offset(0, 1).Value   'Nachname
.HomeAddressStreet = Cells(i, 1).Offset(0, 2).Value   'Straße
.HomeAddressPostalCode = Cells(i, 1).Offset(0, 3).Value   'PLZ
.HomeAddressCity = Cells(i, 1).Offset(0, 4).Value   'Ort
'.HomeAddressTelehoneNumber = Cells(i, 1).Offset(0, 5).Value   'Telefon    ' _
Fehlermeldung
'.MobileTelehoneNumber = Cells(i, 1).Offset(0, 6).Value   'Mobil    ' _
Fehlermeldung
.Email1Address = Cells(i, 1).Offset(0, 7).Value   'eMail
.HomeFaxNumber = Cells(i, 1).Offset(0, 8).Value   'Fax
.BusinessTelephoneNumber = Cells(i, 1).Offset(0, 9).Value  'Tel geschäftl.
.BusinessFaxNumber = Cells(i, 1).Offset(0, 10).Value   'Fax geschäftl.
.Save
End With
'Object entfernen
Set MyOutCon = Nothing
Next i
End With
Set MyOutApp = Nothing
End Sub
~
Kann mir bei der Anpassung der Codes helfen? Vielen Dank schon im voraus.
Mit freundlichen Grüßen
Thomas T.

2
Beiträge zum Forumthread
Beiträge zu diesem Forumthread

Betreff
Benutzer
Anzeige
AW: Outlook-Excel-Outlook
Thomas
Hallo,
ich hab nun des Fehler gefunden warum das mit dem zurück schreiben nicht ging.
Das mit der Formatierung der Telefonnummern habe ich erstmal mit Text gelöst. Bei dem ganzen hin und her schreiben der Liste ist mir eins aufgefallen und dabei brauch ich noch immer Hilfe von euch.
Meine Excelliste wird ergänzt beim einlesen von Outlook aber beim zurück schreiben werden neue Kontakte erstellt und somit doppelte einträge. :(
Also wie kann dies umgangen werden?
Gruß Thomas T.
AW: Outlook-Excel-Outlook
Thomas
Hallo Zusammen,
habe folgenden Code gefunden und angepasst aber wie bei meinem anderen Code werden doppelte einträge in Outlook gemacht und nicht wie da steht das verglichen wird.
Was ist an dem Code falsch oder hab ich wo ein Anpassungsfehler gemacht? Den Code hab ich in einem Modul.
Gruß Thomas
~

Sub Kontakte()
Dim Blatt As Worksheet, Eintragnummer As Integer
Dim Outlookprogramm As Object, Outlookkontakt As Object
'Wo stehen die Kontaktdaten
Set Blatt = Worksheets("Kontakte")
'Outlook Objekt erstellen
Set Outlookprogramm = CreateObject("Outlook.Application")
'Mit "With" wird auf das Tabellenobjekt referenziert
With Blatt
'Zählschleife starten
'Dazu wird der letzten Eintrag in Spalte A bestimmt
'Der Adressenbereich beginn in Zeile 2
'deshalb startet auch die Zählschleife dort
For Eintragnummer = 2 To .Cells(Rows.Count, 6).End(xlUp).Row
Application.StatusBar = Eintragnummer & " Adresse(n) von " & .Cells(Rows.Count, 6).End( _
xlUp).Row & " bereits verarbeitet."
'Outlook Kontaktobject suchen bzw. neu erstellen
Set Outlookkontakt = Kontakt(Outlookprogramm, .Cells(Eintragnummer, 6).Value, .Cells( _
Eintragnummer, 7).Value)
'Eine vollständige Liste der möglichen Felder
'finden Sie in der Outlook-VBA-Hilfe
'Name
Outlookkontakt.FirstName = .Range("A" & Eintragnummer).Value
'Nachname
Outlookkontakt.LastName = .Range("B" & Eintragnummer).Value
'Strasse
Outlookkontakt.HomeAddressStreet = .Range("C" & Eintragnummer).Value
'Postleitzahl
Outlookkontakt.HomeAddressPostalCode = .Range("D" & Eintragnummer).Value
'Stadt
Outlookkontakt.HomeAddressCity = .Range("E" & Eintragnummer).Value
'Telefonnummer
Outlookkontakt.HomeTelephoneNumber = .Range("F" & Eintragnummer).Value
'eMail
Outlookkontakt.Email1Address = .Range("G" & Eintragnummer).Value
'Mobil
Outlookkontakt.MobileTelephoneNumber = .Range("H" & Eintragnummer).Value
'Fax
Outlookkontakt.HomeFaxNumber = .Range("I" & Eintragnummer).Value
'Tel. geschäftl.
Outlookkontakt.BusinessTelephoneNumber = .Range("J" & Eintragnummer).Value
'Fax geschäftl.
Outlookkontakt.BusinessFaxNumber = .Range("K" & Eintragnummer).Value
Outlookkontakt.Save
'Object entfernen
Set Outlookkontakt = Nothing
Next Eintragnummer
End With
Set Outlookprogramm = Nothing
Application.StatusBar = ""
End Sub

Function Kontakt(Outlookprogramm As Object, FirstName As String, LastName As String) As Object
Dim Kontaktordner As Object, item As Object
' öffnet den Standard-Kontaktordner, 10 = olFolderContacts
Set Kontaktordner = Outlookprogramm.GetNamespace("MAPI").GetDefaultFolder(10)
' durchsucht dort alle Kontakte
For Each item In Kontaktordner.Items
' Falls Vor- und Nachname übereinstimmen wird dieser Kontakt zurückgegeben
If UCase(item.FirstName) = UCase(FirstName) And UCase(item.LastName) = UCase(LastName)  _
Then
Set Kontakt = item
Exit Function
End If
Next
' Kein passender Kontakt gefunden, einen neuen Kontakt erstellen
Set Kontakt = Outlookprogramm.CreateItem(2)
' Und dann noch die Namen eintragen
Kontakt.FirstName = FirstName
Kontakt.LastName = LastName
End Function
~
Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Anzeige