Anzeige
Anzeige
Anzeige
Lesedauer 3 Min.

Excel-Import von CAMT.054.xml Dateien

Gemäss dem neuen ISO-Standard 20022 stellen die CH-Banken die ESR-Gutschriftsdateien ab 2018 nur noch als XML-Dateien bereit. Aber wie importiert man sie mit richtiger Darstellung der langen Nummern?

Ein Teil des Makros im Visual-Basic-Editor

© Quelle: PCtipp.ch

Die Referenznummer des verwendeten Einzahlungsscheins ist 27-stellig. Excel stellt diese jeweils als Exponentialzahl dar (z.B. 8.11127102E+26); nur in der Bearbeitungsleiste erscheint die Nummer korrekt. Wenn man versucht, das Feld umzuformatieren, wird die Zahl ab der 15. Stelle nur noch mit Nullen dargestellt (Excel-Standard). Wie kann man die lange Zahl in Excel so importieren, dass sie auch in der Liste korrekt erscheint?

Lösung: Es gibt hierfür ein Makro; eines unserer Forumsmitglieder hat es für Sie ausgetüftelt. Infos über den neuen Standard gibts hier.

Ein Teil des Makros im Visual-Basic-Editor

© Quelle: PCtipp.ch

Öffnen Sie Excel – momentan noch ohne Datei. Lassen Sie erst die Entwicklertools einblenden, falls die in Excel noch nicht zu sehen sind: Klicken Sie hierfür mit rechts auf ein Menüband, gefolgt von Menüband anpassen. Im neuen Dialog haken Sie in der rechten Spalte bei den «Hauptregisterkarten» jene namens Entwicklertools an. Klicken Sie auf OK.

Wechseln Sie zu den Entwicklertools und benutzen darin im linken Bereich den Button Visual Basic. Klicken Sie im neuen Fenster in der linken Spalte doppelt auf Diese Arbeitsmappe. Kopieren Sie untenstehenden Quellcode und fügen Sie ihn ein. Klicken Sie aufs blaue Diskettensymbol und geben Sie einen Dateinamen an. Wichtig: Damit das Makro funktioniert, müssen Sie beim Dateityp zu «Excel-Arbeitsmappe mit Makros (*.xlsm)» greifen.

Option Explicit Dim verz As String   Sub kontoAuszugLaden() Dim pfad As String, datei As String, bName As String, ext As String Dim ret As Long Dim inhalt As String Dim p As Long   ' Es wird erfragt, welche Datei eingelesen werden soll: With Application.FileDialog(msoFileDialogOpen) If verz <> "" Then .InitialFileName = verz .Filters.Add "Konto-Dateien", "*.xml" .InitialView = msoFileDialogViewDetails .Title = "Konto-Datei wählen" If .Show <> -1 Then Exit Sub pfad = .SelectedItems(1) End With   ' Aus dem kopletten Pfad werden das Verzeichnis, der Dateiname, und die Eweiterung extrahiert: verz = Left(pfad, InStrRev(pfad, "\")) datei = Mid(pfad, Len(verz) + 1) bName = Left(datei, InStrRev(datei, ".") - 1) ext = Mid(datei, InStrRev(datei, ".") + 1)   ' Die komplette Datei wird in die Variable "inhalt" gelesen: inhalt = komplettEinlesen(pfad)   ' Wenn der Ausdruck "<Ref>" in der Datei nicht vorkommt, ist es eine falsche Datei: p = InStr(inhalt, "<Ref>") If p = 0 Then MsgBox "Der Datei-Inhalt entspricht nicht dem Konto-Dateiformat", , "Geht nicht!" Exit Sub End If   ' Zwischen die erste und die zweite Ziffer der Referenznummer wird ein nicht druckbares Zeichen (TAB) eingefügt: inhalt = Left(inhalt, p + 5) & Chr(9) & Mid(inhalt, p + 6)   ' Der komplette Datei-Inhalt (Variable "inhalt") wird in eine Datei geschrieben. ' Diese Datei steht im selben Verzeichnis wie die Ursprungs-Datei. ' Sie bekommt den selben Grundnamen wie die Urpsrungsdatei, mit angehängten "_2". komplettSchreiben verz & bName & "_2." & ext, inhalt   ' Die neue Datei wird als XML-Datei geöffnet: Workbooks.OpenXML Filename:= _ verz & bName & "_2." & ext, LoadOption:=xlXmlLoadImportToList Range("A:A,E:E").NumberFormat = "0" End Sub   ' Einlesen einer kompletten Datei in eine Text-Variable: Function komplettEinlesen(datei As String) As String Dim FF As Long    ' Freie Filenummer erfragen: FF = FreeFile    ' Die Textvariable wird vorbereitet: Sie wird in der länge der Datei mit Leerzeichen gefüllt: komplettEinlesen = Space(FileLen(datei))   ' Die Datei wird geöffnet, komplett in die Variable eingelesen und wieder geschlossen: Open datei For Binary As #FF Get #FF, , komplettEinlesen Close #FF End Function   ' Schreiben einer Textvariablen als komplette Datei: Sub komplettSchreiben(datei As String, inhalt As String) Dim FF As Long   ' Freie Filenummer erfragen: FF = FreeFile   ' Die Datei wird geöffnet, mit der Textvariablen beschrieben und wieder geschlossen: Open datei For Binary As #FF Put #FF, , inhalt Close #FF End Sub 

Schliessen Sie das VisualBasic-Fenster wieder. Wenn Sie mögen, können Sie das Makro in einen Knopf in der Schnellzugriffsleiste einbauen. Das geht so: Im linken Bereich des oberen Fensterrandes zeigt Excel eine kleine «Symbolleiste für den Schnellzugriff». Da sind oft schon Vorwärts- und Zurück-Knöpfe drin, sowie z.B. ein Speichern-Icon. Am rechten Rand dieser kleinen Leiste finden Sie ein unscheinbares nach unten weisendes Dreieck. Klappen Sie dies auf und wählen Sie Weitere Befehle. Im neuen Fenster klappen Sie oben das Menü «Befehle auswählen» auf, und schalten Sie dort auf Makros um. Klicken Sie das Makro namens DieseArbeitsmappe.kontoAuszugLaden an, gefolgt von einem Klick auf den Knopf Hinzufügen. Das Makro springt in die rechte Spalte. Klicken Sie es dort an, gefolgt von der Schaltfläche Ändern (unten). Passen Sie den Anzeigenamen an, zum Beispiel «Kontoauszug laden». Wählen Sie auch ein hübsches Icon aus.

Legen Sie das Makro in die Schnellzugriffsleiste

© Quelle: PCtipp.ch

Das Icon erscheint in der Schnellzugriffsleiste. Speichern Sie die Datei. Ab sofort können Sie diese Excel-Datei öffnen, oben auf das Icon klicken und die xml-Datei öffnen. Sie wird über dieses Makro nun korrekt importiert. (PCtipp-Forum)

Kommentare

Office Datenverwaltung Kummerkasten
Anzeige
Anzeige

Neueste Beiträge

Sunrise passt Roaming-Optionen an
Sunrise packt neu mehr Leistung in die Roaming-Optionen für beliebte Reiseziele in Europa, Nordamerika und vielen weiteren Ländern – zu gleichen oder tieferen Preisen.
3 Minuten
23. Mär 2026
Apple-Ecke
iCloud-Backups: wenig Aufwand, viel Wirkung
Apples iCloud ist kein Ersatz für klassische Backups. Doch mit dem richtigen Ansatz wird sie zur wichtigsten Verteidigungslinie gegen Datenverlust. Mit den folgenden Einstellungen werden wasserdichte Sicherheitskopien bei minimalem Aufwand realisiert.
6 Minuten
19. Mär 2026
«ZüriA»
Stadt Zürich lanciert eigene KI-Assistenz
Seit Kurzem steht den Mitarbeitenden der Stadt Zürich mit «ZüriA» eine KI-Assistenz zur Verfügung, die die Bearbeitung von internen, vertraulichen und streng vertraulichen Informationen ermöglicht.
2 Minuten
18. Mär 2026

Das könnte Sie auch interessieren

Apple-Watch-Tipps
Alles für die Gesundheit auf der Apple Watch
Die Apple Watch ist gespickt mit Funktionen, die sich der Überwachung der Gesundheit verschreiben. Damit wird die smarte Uhr zum Schutzengel aller Altersklassen, denn sie kann gesundheitliche Probleme erkennen, bevor sie problematisch werden.
10 Minuten
16. Mär 2026
Windows-Fotos
Fotos gratis bearbeiten
Die bei Windows mitgelieferte Foto-App eignet sich nur für einfachste Aufgaben? Falsch. Microsoft hat sie um nützliche Funktionen wie OCR-Texterkennung und KI-Retuschen erweitert. Der PCtipp gibt Tipps zur optimalen Bedienung.
8 Minuten
12. Mär 2026
Schweizer Bibliotheken
So funktioniert die Bücher-Ausleih-Plattform «Swisscovery»
Mitte November hat «Swisscovery» einen neuen Bestellprozess und weitere Funktionen erhalten. PCtipp erklärt, wie die Ausleih-Plattform funktioniert.
6 Minuten
17. Nov 2022
Anzeige
Anzeige
Anzeige
Anzeige
Anzeige
Anzeige

Kommentare