Datei (CSV-ähnlich) in Java einlesen & mit teil der Daten Graphen erstellen

kakulala

Mitglied
Hallo Leute,
ich habe folgendes Problem. Ich soll eine Datei einlesen, die augenscheinlich eine CSV-Datei ist, aber zwischen den Spalten verstecken sich auch noch andere Trennungszeichen....
Nun soll ich also die Datei einlesen (Export.csv) die erste "spalte" löschen und mit den Werten aus Spalte 2 & 3 einen Graphen erstellen.

Die Datei sieht folgendermaßen aus (beispielhaft jetzt nur 3 Zeilen):
2017-07-12T07:02:53+00:00,2017-07-12T09:02:53+02:00,26.25
2017-07-12T08:02:54+00:00,2017-07-12T10:02:54+02:00,26.08
2017-07-12T09:02:55+00:00,2017-07-12T11:02:55+02:00,25.78

Den ersten Teil "2017-07-12T07:02:53+00:00" würde ich gerne löschen, vom zweiten Teil ist nur die Uhrzeit wichtig "2017-07-12T09:02:53+02:00" und die dritte Spalte ganz "26.25".
Anschließend würde ich gerne die Uhrzeit und die Temperatur in einem Graphen darstellen.

Ich weiß leider überhaupt nicht wie ich anfangen soll....sowie ich das verstanden habe brauche ich den BufferedReader zum Einlesen der Datei & am besten wäre es sie zeilenweise einzulesen. Aber wie lösche ich denn genau den ersten Teil der Zeile & wie kann ich auf die anderen Teile zugreifen??
Für die graphische Darstellung ist es sinnvoller ein Framework ( jFreeChart) zu benutzen oder geht das auch darstellen von Graphen mit den ausgelesenen Daten auch anders?
Danke für hilfreiche Antworten!!
 

Robat

Top Contributor
Das einlesen kannst du, wie du bereits richtig gesagt hast, bspw. mit einem BufferedReader machen.

Wenn du die Datei nun Zeile für Zeile einliest, kannst du ja selber bestimmen welche Abschnitte der Zeile du verwirfst und welche du abspeichern willst.
Du könntest erstmal sagen dass du die Zeile am Komma splittest. Dann hättest du ein Array mit 3 Teilen: 2017-07-12T07:02:53+00:00, 2017-07-12T09:02:53+02:00 und 26.25.

Das 1. Array-Element benutzt du einfach nicht weiter.
Beim 2. Element könntest du dir die Uhrzeit mit einem regulären Ausdruck rausfiltern. (Gibt auch noch andere Möglichkeiten wie bspw. am T und am + splitten).
Das 3. Element kannst du so lassen wie es ist.

Jetzt nimmst du deine Datenstruktur (welcher Art auch immer) zur Hand und speicherst die beiden Werte darin. Das machst du für jede Zeile und schon hast du deine Uhrzeit / Temperatur ;)

Ob du für die Darstellung ein Framework benutzt oder es selber zeichnest ist deine Entscheidung. Beides sollte nicht so schwer sein.
 

kakulala

Mitglied
Okay, schonmal vielen Dank! Ich bin noch nicht soo erfahren mit Java & versuch mir möglichst viel beizubringen. Also das einlesen & splitten hat schonmal geklappt. Einlesen mit BufferedReader. Jetzt habe ich aber eine ArrayList verwendet, da ich nicht genau weiß wieviel bzw wie groß die Datei wird bzw werden soll:)
Sieht dann so aus:
Java:
//Splitten am Komma
    final String[][] valuesArray = new String[lines.size()][];
    int cnt = 0;
    for (final String line : lines) {
        valuesArray[cnt++] = line.split(",");
    }

 
    // Ausgabe des eingelesenen Arrays
    for (String[] arr : valuesArray) {
        System.out.println(Arrays.toString(arr));
    }

Jetzt kann ich aber nicht die Liste noch splitten oder? Also spaltenweise? Was meinst du denn mit regulären Ausdrücken rausfiltern? Hab damit noch nicht wirklich was zutun gehabt...kannst du das kurz erklären?
 

Flown

Administrator
Mitarbeiter
Einfach mit:
Java:
String input = "2017-07-12T07:02:53+00:00,2017-07-12T09:02:53+02:00,26.25\n" +
  "2017-07-12T08:02:54+00:00,2017-07-12T10:02:54+02:00,26.08\n" +
  "2017-07-12T09:02:55+00:00,2017-07-12T11:02:55+02:00,25.78 ";
try(StringReader sr = new StringReader(input);
    BufferedReader reader = new BufferedReader(sr)) {
  String line;
  while((line = reader.readLine()) != null) {
    String[] split = line.split(",");
    System.out.println(ZonedDateTime.parse(split[1]).format(DateTimeFormatter.ISO_LOCAL_TIME) + "," + split[2]);
  }
} catch (IOException e) {
  e.printStackTrace();
}
 

kakulala

Mitglied
Danke, aber du definierst jetzt ja den String input...im Idealfall geht das ja nicht, da die Datei eingelesen werden soll & es dann nicht möglich ist, den input zu definieren. Oder hab ich da jetzt was falsch verstanden bei deinem Code?
 

Flown

Administrator
Mitarbeiter
Dann übergibst du dem BufferedReader einfach einen FileReader? Ein wenig Eigeninitiative ist schon gefragt.
 

kakulala

Mitglied
Danke! Hab das ursprünglich ein bisschen anders gemacht. Wie gesagt, bin noch ned soo lange dabei mir das beizubringen. Dürfte jetzt aber so passen:

Code:
 FileReader myFile = null;
    BufferedReader buff = null;
    final ArrayList<String> lines = new ArrayList<String>();
    try {
        myFile = new FileReader("C:/Users/......./Desktop/Datei.csv");
        buff = new BufferedReader(myFile);
        String line;
        //Überspringen der ersten Zeile, da nichts wichtiges drinsteht
        buff.readLine();//erste Zeile lesen
       
       
        while ((line = buff.readLine()) != null) {
           
            //Splitten der Datei am Komma
            //Da Array bei [0] beginnt und das wegfallen soll, beginne bei eins
            String[] split = line.split(",");
             System.out.println(ZonedDateTime.parse(split[1]).format(DateTimeFormatter.ISO_LOCAL_TIME) + "," + split[2]);
           
            // Anzeige was eingelesen wurde
            // System.out.println(line);
            lines.add(line);


Hast du denn noch ein Beispiel wie man das mit regulären Ausdrücken lösen könnte? Oder ein allgemeines, wie ich damit filtern kann?
 

Harry Kane

Top Contributor
Hast du denn noch ein Beispiel wie man das mit regulären Ausdrücken lösen könnte? Oder ein allgemeines, wie ich damit filtern kann?
Ich glaube nicht, dass dein Problem (Datei zeilenweise einlesen, an einem Trennzeichen splitten, dann die Teile einzeln vcerwerfen oder weiterverarbeiten) mit regulären Ausdrücken einfacher gelöst werden kann.
Zum erstellen von Charts kann ich JFreeChart wärmstens empfehlen.
 
Zuletzt bearbeitet:

mrBrown

Super-Moderator
Mitarbeiter
Hast du denn noch ein Beispiel wie man das mit regulären Ausdrücken lösen könnte? Oder ein allgemeines, wie ich damit filtern kann?
Ein passender Regulärer Ausdruck dafür wäre zB .*,.*(\d{2}:\d{2}:\d{2}).*,.*(\d{2}\.\d{2}).
Der erste Ausdruck in Klammern matcht auf die Uhrzeit, der zweite in Klammern auf die Temperatur.

Für deinen UseCase ginge das zB mit:

Java:
Pattern pattern = pattern.compile(".*,.*(\\d{2}:\\d{2}:\\d{2}).*,.*(\\d{2}\\.\\d{2})");
Matcher matcher = pattern.matcher("2017-07-12T07:02:53+00:00,2017-07-12T09:02:53+02:00,26.25")
if (matcher.find()) {
  System.out.println(ZonedDateTime.parse(matcher.group(1)).format(DateTimeFormatter.ISO_LOCAL_TIME) + ", " + matcher.group(2));
}
 

JStein52

Top Contributor
Wenn du es so machst kompiliert es erstens fehlerfrei und läuft auch ohne Exception :):):
Code:
        Pattern pattern = Pattern.compile(".*,.*(\\d{2}:\\d{2}:\\d{2}).*,.*(\\d{2}\\.\\d{2})");
        Matcher matcher = pattern.matcher("2017-07-12T07:02:53+00:00,2017-07-12T09:02:53+02:00,24.25");
        if (matcher.find()) {
            System.out.println(matcher.group(1) + ", " + matcher.group(2));
        }
und die Temperatur darf nicht unter 10° fallen es werden nämlich Temperaturen im zweistelligen Bereich erwartet.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Kann man System.out in eine Datei speichern? ähnlich wie log Allgemeine Java-Themen 7
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
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