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

ggs netz übernimmt sämtliche Kommunikationsnetze der GIB-Solutions
Die ggs netz ag übernahm per 1. Mai 2026 sämtliche Kommunikations-netze der GIB-Solutions AG. Mit der Transaktion kommen rund 10’000 Digitalanschlüsse hinzu. Die übernommenen Netze werden künftig über die neu gegründete Tochtergesell-schaft ggs plus ag betrieben.
3 Minuten
Stromverbrauch und Effizienzpotenziale von Rechenzentren in der Schweiz
2024 betrug der Stromverbrauch der Rechenzentren in der Schweiz 2,1 TWh, was ungefähr 3,6 Prozent des Gesamtverbrauchs entspricht. Bis 2030 wird ein Anstieg des Stromverbrauchs der inländischen Rechenzentren auf 2,5 bis 3,2 TWh erwartet. 
3 Minuten
Echtzeittext - Bundesrat schafft Grundlage für neue Notruffunktion
Der Bundesrat hat mehrere Verordnungen angepasst, um ein sicheres Notrufsystem zu fördern. In Zukunft können Menschen in Notlage die Notdienste von Polizei, Feuerwehr und Sanität per Echtzeittext auf den Smartphones auch schriftlich erreichen. 
3 Minuten

Das könnte Sie auch interessieren

Apple-Ecke
Lineár Calendar: das ganze Jahr im Blick
Wer kennt sie nicht, die Jahreskalender im Büro: Sie zeigen einen schnellen Überblick darüber, was in diesem Jahr noch kommen wird.
2 Minuten
28. Apr 2026
Outlook-Tipps
Das neue Outlook
Microsoft hat seine beliebte E-Mail- und Organisations-Software Outlook komplett überarbeitet. Wir zeigen Ihnen Schritt für Schritt, wie Sie die neue Version einrichten, bedienen und optimal auf Ihre Bedürfnisse anpassen.
9 Minuten
10. Apr 2024
Sicherheitstipps
So wird Windows sicher
Nutzen Sie unsere Konfigurationstipps und sichern Sie damit Ihr Windows besser ab. Meist reichen bereist ein paar Klicks oder ein Häkchen aus. Die folgende Anleitung führt Sie Schritt für Schritt durch alle wichtigen Schutzoptionen. 
8 Minuten
17. Apr 2026
Anzeige
Anzeige
Anzeige
Anzeige
Anzeige
Anzeige

Kommentare