Problem mit CSV-Import in OpenOffice

Sekundentakt

Bekanntes Mitglied
Hallo Gemeinde,

ich konnte über die üblichen Suchmaschinen leider keine Informationen zum entsprechenden Thema finden.

Folgendes ist das SQL-Statement, mit dem die Datei erzeugt wird:

SQL:
SELECT...
INTO OUTFILE "'../output"
				FIELDS 	TERMINATED BY "," ENCLOSED BY "'"
						LINES TERMINATED BY "\n"';
In OpenOffice stelle ich entsprechend Als Spaltentrenner "," und als Texttrenner ein einfaches Anführungszeichen ein.

Wenn ich das Ganze via SQL-Befehl wieder in eine Datenbank einspielen will, klappt das auch wunderbar. Die Daten werden richtig eingelesen.
In OpenOffice werden dagegen die Zeilen teilweise zerschossen.
In den Datensätzen der CSV-Datei kommen selbst auch Daten mit einfachen, wie auch doppelten Anführungszeichen vor.

Ich frage mich jetzt natürlich, ob die Datei falsch exportiert worden ist.
In die Datenbank wird sie schließlich mit der selben Datenbank-Software (MySQL) wieder eingespielt. MySQL könnte diesen Bug also selbst gefixed haben, ohne das es zu Inkompatibilitäten kommt.
Das das aber auf lange Sicht so geblieben wäre, kann ich mir nicht denken.

Die nächste Möglichkeit bestünde darin, dass OpenOffice hier die Daten falsch einliest und der Fehler bei Open Office liegt.

Das Problem entsteht genau dort, wo das letzte Zeichen eines Feldinhaltes ein einfaches Anführungszeichen ist. Ich vermute, dass sich dadurch beim Parsen irgendetwas verschiebt und erst dann wieder einrenkt, wenn die selbe Situation bei einem anderen Datensatz auftritt. Zumindest geht das aus meinen Beobachtungen hervor. Woher sollte OpenOffice auch wissen, dass das betroffene Zeichen noch zum Feldinhalt gehört?

Irgendeine Idee, wie man das via SQL lösen könnte?

ESCAPED BY hat bisher keine Wirkung gezeigt und möchte ich im Moment auch nicht verwenden, weil ich nicht weiß, wie ich es in SuperCSV einbringen soll.

Danke für jeden Ansatz!

Beste Grüße

EDIT: Zur Situation:
Die CSV-Datei wird aus der Datenbank exportiert und soll anschließend von einem Programm abgeholt und eingelesen werden.
Falls Dritte aber interessiert, wie die fertige CSV aussieht, warum auch immer, soll die Darstellung in Programmen wie OO korrekt laufen.
Da die Weiterverarbeitung zum ersten mal für mich mit SuperCSV erfolgt, will ich im Voraus sicherstellen, dass der Export auch korrekt funktioniert.
Ich will dadurch vermeiden, Fehler in SuperCSV-Code bzw. meiner Anwendung zu suchen, wenn diese Fehler von ganz anderen Stellen zu verantworten sind.
 
Zuletzt bearbeitet:

Sekundentakt

Bekanntes Mitglied
So steht die vermeintliche Problemstelle in der CSV (Klartext, nicht OO-formatiert)

-Datamax-O\'Neil-
Die Bindestriche zu Beginn und Ende habe ich via SQL-Statement angeführt, weil ich wissen wollte, ob ein Problem mit dem einfachen Anführungsstrich am Ende der Zeile besteht. Dabei kam dann heraus, dass der Anführungsstrich gar nicht zum Datensatz gehört, sondern fälschlicherweise der Texttrenner angezeigt wird.

Interessanterweise wird in der OpenOffice Spalte folgendes angezeigt:
-Datamax-O\Neil-'
Die Zeile wird also nicht zerschossen, dafür aber nicht mehr richtig geparsed.

Eigentlich müsste es nämlich so aussehen:

Kann es sein, dass das ein OO-Bug ist?
 

Sekundentakt

Bekanntes Mitglied
Ich glaube, ich habe das Problem in OO gelöst. Zumindest für's erste.., wenn auch nicht zufriedenstellend.

SQL:
FIELDS TERMINATED BY "^"
	LINES TERMINATED BY "\r\n"
Sobald ich spezifiziere, wie die Spalten "enclosed" werden sollen, gab es hier Fehler.

Nun werden die Spalten gar nicht mehr durch Zeichen umschlossen.

Der ENCLOSED BY - Befehl verursacht also Formatierungsfehler, da sowohl " als auch ' im Text vorkommen können.

Was mich wundert, ist, wie OO hier mit escpaten Werten umgeht.

Hier geht's wohl um ein ähnliches Problem.
csv files and text delimiter (View topic) • OpenOffice.org Community Forum
 

Sekundentakt

Bekanntes Mitglied
1,"a string",100.20
2,"a string containing a , comma",102.20
3,"a string containing a \" quote",102.20
4,"a string containing a \", quote and comma",102.20
Ein Beispiel aus der offiziellen MySQL-Doku.

Wenn Du das in OO darstellen willst, wird's zerschossen.
 

ice-breaker

Top Contributor
also ich hab eben mal mit PHP rumgespielt und dort den CSV-Export ausprobiert, folgendes wird von OO korrekt erkannt:
Code:
4,"a string containing a "", quote and comma",102.2

In der englischen Wikipedia finde ich dazu dann auch noch:
Fields with embedded double-quote characters must be enclosed within double-quote characters, and each of the embedded double-quote characters must be represented by a pair of double-quote characters.

also sieht das für mich nach fehlerhaftem Export durch MySQL aus oder Fehlbedienung.
 
Zuletzt bearbeitet:

Sekundentakt

Bekanntes Mitglied
Das habe ich schon fast befürchtet.

Ich möchte aber möglichst vermeiden, dass die Datei durch PHP oder Java selbst erstellt wird.
PHP, weil man da früher oder später in TimeOuts rennt und Java, weil es weniger verbreitet ist.

Bleibt also nur noch via replace im SQL-Statement einfache Anführungszeichen zu verdoppeln.
Oder?

EDIT: Soweit ich das sagen kann, funktioniert der Ansatz alle Spalten einem REPLACE zu unterziehen bisher ohne Probleme.

Der Outfile-Part der SQL-Anweisung enthält somit nur noch FIELDS TERMINATED BY und LINES TERMINATED BY. Alles andere funktionierte nicht fehlerfrei.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
E (einfaches) Problem mit import und package (export) Allgemeine Java-Themen 4
D Problem mit import von jdic Systemtray Allgemeine Java-Themen 2
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben