CSV-Datei (korrupt?) auswerten

Raziell

Bekanntes Mitglied
Hallo zusammen,

ich möchte mal ein kleines Programm schreiben, welches exportierte CSV-Dateien vom Online-Banking
erfasst und auswertet. Dabei ist mir ein etwas seltsamer Aufbau der CSV aufgefallen.

Die Datei ist in etwa so aufgebaut:

"20.10.2010";"20.10.2010";"0000000";"text1";"text2";"text3";"text4";"EUR";"30,00";"S"
"20.10.2010";"20.10.2010";"0000000";"text1";"text2";"text3";"text4";"EUR";"30,00";"S"
"20.10.2010";"20.10.2010";"0000000";"text1";"text2";"text3";"text4";"EUR";"30,00";"S"

Das seltsame daran finde ich jetzt, dass nicht jeder Datensatz in einer Zeile ist, sondern dass bei längeren Texten dann ein Zeilenumbruch gemacht wird. Also manchmal erstreckt sich ein Datensatz über 2 und manchmal über 3 Zeilen.

Ist der Aufbau der Datei korrekt oder ist die Datei korrupt?

Gruß
 
S

SlaterB

Gast
wieso postest du kein Beispiel dieser mehreren Zeilen, wenn das das Problem zu sein schein?

eine allgemeine Definition von 'korrupte CSV-Datei' gibt es wohl nicht,
entweder du selber siehst das als ok an oder nicht,
wenn dein Java-Programm damit umgehen kann ist es wohl nicht so kritisch

kannst noch testen was die allgemeinen Excel-Importe dazu sagen, wenn die versagen, dann ist es wiederum nicht so gut,
aber Excel hat auch kein Patent darauf..

CSV (Dateiformat) ? Wikipedia
Das Dateiformat CSV beschreibt den Aufbau einer Textdatei zur Speicherung oder zum Austausch einfach strukturierter Daten. Die Dateiendung .csv ist eine Abkürzung für Comma-Separated Values (selten Character Separated Values[1][2][3]). Ein allgemeiner Standard für das Dateiformat CSV existiert nicht.
 

Raziell

Bekanntes Mitglied
Hallo,

im Anhang ein kleines Beispiel vom Aufbau der Datei.

Ich müsste in meinem Fall also zwangsweise davon ausgehen, dass nach einer bestimmten Anzahl von Trennzeichen der nächste Datensatz beginnt?

Oder ich könnte auch davon ausgehen, dass nach jedem ;"S" bzw. ;"H" ein neuer Datansatz beginnt.

Vllt. habt ihr ja einen besseren Vorschlag...

Danke

Gruß

EDIT:

Der Import in Excel bzw. OpenOffice klappt reibungslos.
 
S

SlaterB

Gast
die Zeilenumbrüche sind hier innerhalb von Anführungszeichen, dass kann man verarbeiten, das kann sogar Excel richtig erkennen,

komisch sind die wirklich kompletten Leerzeilen nach jedem "S",
das kann dir als extremer Hinweis auf den nächsten Datensatz helfen oder einfach ignorien
 
M

maki

Gast
Würde nicht Kommas oder Semikolons als Trennzeichen einsetzen sondern Tabs oder etwas anderes das garantiert nicht in den texten vorkommen kann.
 

XHelp

Top Contributor
Sieht doch in Ordnung aus.
Parst du die Datei selbe? Es gibt ja schon fertige CSV-Parser.
Du kannst davon ausgehen, dass ein Datensatz 1 Zeile ist. Die Werte, die in Anführungszeichen gesetzt sind (vor allem die Mehrzeiligen), stellen 1 Eintrag dar.
 

Raziell

Bekanntes Mitglied
Ja ich finde den Aufbau auch eher bescheiden, aber ich bekomme die Datei leider so ausgeliefert.

Das Problem ist ja, dass ich keine klare Trennung zwischen den einzelnen Datensätzen habe, da ein Datensatz über mehrere Zeilen gehen kann.
Und die Standard CSV-Parser wie opencsv gehen ja davon aus, dass ein Datensatz in einer Zeile steht, wenn ich das richtig verstanden habe.

Gruß
 

XHelp

Top Contributor
Ja, aber jeder ansatzweise sinnvoller Parser kann mit escap'ten (hmm... ob da ein deutsches Wort dazu gibt?) Werten umgehen. Denn die Anführungszeichen sind ja dafür da. Deine Datensätze stehen ja auch, sogesehen, in einer Zeile. Nur eben ein Eintrag (der für sich aber nur als eine Einheit gewertet wird) geht über mehrere Zeilen.
 

Raziell

Bekanntes Mitglied
Achso ich dachte der Parser kommt damit nicht klar aber es funktioniert, der Parser spuckt bei folgendem Beispielcode:
Java:
    try {
      final CSVReader reader = new CSVReader(new FileReader("Beispiel.csv"), ';', '"');

      String[] nextLine;
      try {
        while ((nextLine = reader.readNext()) != null) {
          for (final String element : nextLine) {
            System.out.println(element);
          }
        }
      } catch (final IOException e) {
        e.printStackTrace();
      }
    } catch (final FileNotFoundException e) {
      e.printStackTrace();
    }

das aus:

20.10.2010
20.10.2010
5660056
ARAL aaaaaaaaaaaaaaaaaaaaaa
1234567
1234567
Lastschrift
00000000000000000000000000
OLV71028517 18.10 07.48 ME2
EUR
30,00
S

12.10.2010
12.10.2010
F000000000000 0000000000
AGIP, ASDFFG, ASFDFASASFSCH
1234567
1234567
Lastschrift
EC 0000000 0000000000000E0
EUR
30,00
S

04.10.2010
04.10.2010
008056 1112 0102
GA NR000000000 BLZ000000000 2
1234567
1234567
Lastschrift
02.10/19.20UHR ASDF-AUTO
EUR 50,00
EUR
50,00
S

Hätte es vllt. erstmal probieren sollen :D

Danke und Gruß
 
Zuletzt bearbeitet:

Raziell

Bekanntes Mitglied
Hallo nochmal,

mir ist gerade aufgefallen, dass opencsv die Datei doch falsch parst.

In dem Fall nämlich:

04.10.2010
04.10.2010
008056 1112 0102
GA NR000000000 BLZ000000000 2
1234567
1234567
Lastschrift
02.10/19.20UHR ASDF-AUTO
EUR 50,00
EUR
50,00
S

sind für Ihn: EUR 50,00 und EUR ein eigener Datensatz obwohl die beiden Werte zur vorherigen
Zeile gehören und im gleichen Quote stehen.

Ich habe jetzt schon eine weile rumprobiert aber iwie klappts nichts richtig ???:L

Kann mir da evtl. jmd. weiterhelfen?

EDIT:

Ok also habs jetzt nochmal zusätzlich mit dem CSVParser probiert und dabei den \n als escape
Zeichen angegeben. Scheint jetzt zu funktionieren...
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
kodela StatusBar-Anzeigen auch in Log-Datei ausgeben Allgemeine Java-Themen 3
G Maven Projekt JAR-Datei Allgemeine Java-Themen 6
E XML - Datei Darstellung in IntelliJ als Baum Allgemeine Java-Themen 2
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
J Filenotfoundexception obwohl Datei existiert Allgemeine Java-Themen 6
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
S .exe Datei/Programm auslesen? Allgemeine Java-Themen 2
E Datei verschoben Event Allgemeine Java-Themen 3
D Datei mit "Kohsuke GitHub API" in Repository hochladen Allgemeine Java-Themen 2
S Bookmark HTML Datei einlesen, alle Links erhalten und manche editieren..? (aktuell JSoup) Allgemeine Java-Themen 4
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
G JavaFX Maven Projekt als .exe Datei exportieren Allgemeine Java-Themen 10
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
Neumi5694 Datei komprimiert Allgemeine Java-Themen 6
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
E java mithilfe url .jar datei öffnen Allgemeine Java-Themen 9
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Master3000 Java Datei mehrmals einlesen Allgemeine Java-Themen 4
M Excel Datei Erstellen Allgemeine Java-Themen 2
E Input/Output Eigene Datei mit java öffnen Allgemeine Java-Themen 9
R Sonderzeichen aus Datei einlesen und in Datei ausgeben. Allgemeine Java-Themen 17
Tobero Download .jar von github lädt kaputte Datei runter Allgemeine Java-Themen 3
P Bat Datei in Java ausführen Allgemeine Java-Themen 2
S Verwendet Programmiersprache aus Quellcode - Datei ermitteln Allgemeine Java-Themen 6
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
J Jar-Datei ausführen Allgemeine Java-Themen 7
C Outlook msg-Datei Anhänge extrahieren Allgemeine Java-Themen 2
G Datei aus Ordner wählen, ohne den Dateinamen im Pfad angeben zu müssen Allgemeine Java-Themen 4
G Datei senden via Xmodem an Serial-Port Allgemeine Java-Themen 35
C Wav-Datei aus Jar laden? Allgemeine Java-Themen 11
L Best Practice Zip Datei aktualisieren Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
Gaudimagspam CSV-Datei auslesen in Java Allgemeine Java-Themen 7
S createTempFile erstellt keine temporäre Datei Allgemeine Java-Themen 13
Hatsi09 Jar datei ausführen verursacht NumberFormatException Allgemeine Java-Themen 9
kodela bestimmten Dateityp immer mit jar-Datei öffnen Allgemeine Java-Themen 17
N Arrayliste in eine Datei speichern Allgemeine Java-Themen 4
B .txt Datei erstellen und auslesen bzw. schreiben Allgemeine Java-Themen 6
J Öffnen eine jar-Datei Allgemeine Java-Themen 11
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
H ArrayListe in CSV Datei speichern Allgemeine Java-Themen 6
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
N Txt Datei auslesen. Allgemeine Java-Themen 5
B Datei/Ordner auf Server zugreifen/erstellen Allgemeine Java-Themen 2
MiMa Datei verschieben hat einen Fehler?? Allgemeine Java-Themen 20
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
O xlsx Datei auslesen mit POI Apache liest keine LEERZELLEN Allgemeine Java-Themen 6
P Input/Output entfernte Datei mit Java öffnen ohne Download Allgemeine Java-Themen 5
O xlsx Datei auslesen mit POI von Apache wirft seltsamen Fehler. Allgemeine Java-Themen 11
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
J Fehlermeldung bei Ausführung von .jar-Datei Allgemeine Java-Themen 9
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
F Datei in String-Array einlesen Allgemeine Java-Themen 8
O docx-Datei erzeugung mit DocXStamper funktioniert nicht Allgemeine Java-Themen 2
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
Bluedaishi Prüfen ob Datei noch geöffnet ist Allgemeine Java-Themen 59
I Temp-Datei wird nicht gelöscht Allgemeine Java-Themen 12
D ODS.Datei öffnet leider in Excel Allgemeine Java-Themen 3
L JavaFX JavaFX Chart in Apache Poi Excel Datei Allgemeine Java-Themen 2
D .txt Datei in .jar Datei speichern Allgemeine Java-Themen 3
ralfb1105 Blöcke aus Datei filtern/suchen und in neue Datei schreiben Allgemeine Java-Themen 10
M Daten aus MatLab Datei lesen Allgemeine Java-Themen 8
L SQL Datei in Eclipse erstellen Allgemeine Java-Themen 3
Drachenbauer Wie sorge ich dafür, dass mein Spiel die ini-Datei in der Resourcen-ordner des Projektes schreibt? Allgemeine Java-Themen 5
Trèfle Excel-Datei nicht speicherbar, da von Java zum Bearbeiten gesperrt. Allgemeine Java-Themen 3
N Datei Zeilenweise Einlesen, Versteckte Zeichen Allgemeine Java-Themen 5
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
G Workupload datei mit Java Downloaden Allgemeine Java-Themen 6
H .jar Datei startet nicht richtig bei Doppelklick Allgemeine Java-Themen 11
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
M Java Eclipse- Datei exportieren Allgemeine Java-Themen 5
R jar-Datei funktioniert nicht Allgemeine Java-Themen 2
R .txt Datei einlesen und auf der Konsole ausgeben lassen Allgemeine Java-Themen 11
T Jar Datei nicht ausführbar Allgemeine Java-Themen 6
H jar-Datei mit java.exe anstatt mit javaw.exe ausführen Allgemeine Java-Themen 9
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
A Steuerung von Spiel aus Datei lesen Allgemeine Java-Themen 0
Javafan01 .sh datei in Java ausführen Allgemeine Java-Themen 1
MiMa Speichern von Programmeinstellungen in Datei Allgemeine Java-Themen 7
J Ordner und Datei Struktur einer War Datei Allgemeine Java-Themen 1
J XML Datei mit installiertem Programm öffnen Allgemeine Java-Themen 7
L Weg um Datei zuzuordnen? Allgemeine Java-Themen 3
MiMa Datei kann nicht umbenannt oder verschoben werden ?? Allgemeine Java-Themen 17
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
K Erste Schritte Start einer JAR Datei 2 Wege aber einmal nicht die volle Funktionlität Allgemeine Java-Themen 20
J Datei löschen, die Leerzeichen im Pfad hat Allgemeine Java-Themen 5
Aruetiise " in Datei schreiben Allgemeine Java-Themen 2
K Datei (CSV-ähnlich) in Java einlesen & mit teil der Daten Graphen erstellen Allgemeine Java-Themen 9
S Korrekte Pfadangaben damit eine .jar Datei unter Windwos läuft. Allgemeine Java-Themen 24
The Pi NetBeans Bilder in Jar Datei werden nicht angezeigt Allgemeine Java-Themen 7
RalleYTN Audiolänge einer MP3 Datei erhalten ohne diese vollständig zu laden Allgemeine Java-Themen 15
H Jar-Datei öffnet nur teilweise Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben