csv Datei mit unterschiedlichen Formatierungen einlesen

Status
Nicht offen für weitere Antworten.

H2SO3-

Bekanntes Mitglied
Hallo an all die klugen Java Köpfe da draußen,

Ich habe eine ziemlich Nuss zu knacken und hoffe jemand kennt etwas, was dies bereits so etwa kann.

Ich möchte csv dateien einlesen. Soweit ja kein Problem das Problem ist nun folgendes.

- der Seperator für die Spalten kann unterschiedlich sein (, ; @ usw)
- der seperator für den zeilenumbruch kann unterschiedlich sein (\n oder ;\n zb.)
- mal stehen in der ersten Spalte die Spaltentitel drinne, mal nicht
- der Seperator für die Spalten kann als nicht Seperator drinne stehen. zb. ein string mit einem , wobei der string dann mit "" oder ' ' eingekesselt ist
- ich möchte die csv datei in eine Tabelle schreiben. Diese hat eventuell bereits passende Spalten, oder halt nicht.
- die Typen für die Spalten sollen den tatsächlichen entsprechen. Also nicht alles string sonder halt zb. int oder double. Wobei ich eventuell nicht weiß was es für ein Typ ist
- der Spalten Typ Datum kann sowohl das Amerikanische wie das deutsche Datum enthalten (entweder oder)

So ich denke mal das waren solangsam alle bedingungen die erfüllt werden müssen :D

Was natürlich auch noch sein soll, eine csv datei die eine Tabelle mit zb. 20 Spalten und 10.000 Zeilen ergibt soll einigermaßen schnell eingelesen werden können, also keine halbe Stunde brauchen.

Hoffe jemand hat ne Idee dafür, bzw kennt ein Programm was sowas kann.
Ansonsten muss ich da nähmlich von null auf ran :bahnhof: :bahnhof:
 

H2SO3-

Bekanntes Mitglied
gegoogelt habe ich schon stunden. Jedoch immer nur programme bzw. code gefunden, der von voraussetzungen ausgeht. Also zb. der seperator ist immer , und kommt in keinem string vor usw. Dies kann ich (siehe oben) leider so nicht gebrauchen.
 
S

SlaterB

Gast
aber du kannst dir sicher vorstellen, dass ein Programm nicht von alleine denken kann,
wenn das Trennzeichen nicht bekannt ist, dann ist selbst für einen Menschen evtl. unmöglich, es zu erkennen, stell dir eine CSV-Datei

,;,;,;,;
;,;,;,;
,;,;,;,;
;,;,;,;
,;,;,;,;

vor ;)

oder
heute;morgen,gestern;übermorgen,dienstag


entweder muss das Programm mit allen nötigen Infos konfiguriert werden (wie beim Excel-Import)
oder den Inhalt einlesen und selber analysieren = raten, welches Trennzeichen zu wählen ist

teste z.B. für die üblichen Verdächtigen wie ; die Anzahl der Vorkommen pro Zeile,
wenn das jeweils 5 ist, dann sieht das schon gar nicht schlecht aus,

ein Programm, was sowas schon macht, wirst du wahrscheinlich nicht bei google oder sonstwo finden,
falls das deine Frage ist, aber vielleicht weiß ja doch jemand was
 

H2SO3-

Bekanntes Mitglied
ich will gar kein Programm welches selber versucht herauszufinden, was der trenner ist. Dies währe zu gefährlich. Der trenner soll halt mitgegeben werden. Bei den einzelnen csv dateien ist es dem programierer schon klar, was da reinkommt. Es soll also alles mitgeben werden.

Also zb. Csv_Import(Tabelle_wo_daten_reinkommen, zeilenseperator, spaltenseperator, filename_+_Pfad, ...)
{

}

Jedoch auch ein solches konnte ich bisher absolut nicht finden.
 

Ark

Top Contributor
Schon mal daran gedacht, das Ding einfach selbst zu schreiben? Wikipediaartikel zu CSV aufgeschlagen, gecheckt und los geht's!

Ark
 
S

SlaterB

Gast
was meinst du dann mit
> Also zb. der seperator ist immer ,

das wird doch wohl irgendwo im Quellcode stehen und kannst du dann gegen was anderes austauschen

wenn du fertige Libraries ohne Quellcode verwendest, wirds natürlich etwas schwieriger,
von obiger Google-Suche führt vieles zu 'CSVReader',

da gibts aber anscheinend auch
http://javacsv.sourceforge.net/com/csvreader/CsvReader.html#setDelimiter(char)

---------

> Csv_Import(Tabelle_wo_daten_reinkommen [..]

wenn überhaupt wirst du die Daten nur als String herausbekommen,
dass sie an eine JTable oder dessen Model sinnvoll weitergeleitet werden ist fast ausgeschlossen
 

H2SO3-

Bekanntes Mitglied
bin ich ja gerade dabei, nur währs halt schön gewesen, wenn ich das Rad (bzw den csv reader) nicht hätte neu erfinden müssen.
 

H2SO3-

Bekanntes Mitglied
subercsv habe ich mir schon angeschaut, soweit ich das sehe, wird da auch davon ausgegangen, das der Seperator , oder ; ist
 
S

SlaterB

Gast
siehe mein vorheriges Posting, eine solche leicht zu ändernde Sache wird nirgendwo fest vorgeschrieben sein
 

lhein

Top Contributor
Meine Güte, diese ganze Diskussion hier dauert inzwischen länger als sich einen CSV-Parser für seinen eigenen Zweck zu schreiben. Wo ist das Problem? Mach die dynamischen Bestandteile der CSV konfigurierbar und dann ist gut.
 

H2SO3-

Bekanntes Mitglied
ich glaube auch, ich werde es einfach selber schreiben.

Nur noch ne Frage in die Runde.
Kennt jemand eine gute schnelle Methode den gesamtstring einer datei auszulesen? Meine also nicht mit readLine() sondern den gesamten string inklusive der zeilenseperatoren.

Ist es hier am perfomantesten wenn ich mir alle zeichen in einchar[] packe und mir anschlißend meinen string wieder zusammenbaue oder gibt es hier schon was festes.
 

lhein

Top Contributor
Ich würde Dir dringend raten, beim Reader zu bleiben. Die CSV Datei wirst Du sicherlich zeilenweise parsen, von daher bietet sich das an und arbeitet u.a. auch noch resourcenschonender als alles in den Memory zu laden.
 

HoaX

Top Contributor
naja, ich hätte keine lust mit escapes usw in den texten rum zu schlagen. das rad wurde schon mehr als einmal neu erfunden, und gerade supercsv lässt kaum wünsche offen.

wert1,"wert 2, und , \" noch, mehr","wert3",...

supercsv unterstützt sogar cellprocessors, so dass du statt nem string z.B. n Date zurückbekommst, klar kannst du auch die trenner angeben, ein blick in die beispiele reicht ...

http://supercsv.sourceforge.net/javadoc/org/supercsv/prefs/CsvPreference.html
 
Status
Nicht offen für weitere Antworten.
Ä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