CSV-Datei (Spalt A -> Excel) in Array packen und auslesen

Status
Nicht offen für weitere Antworten.

Andre1978

Mitglied
Hallo liebe Forum-Besucher!

Habe ein Problem, weiss nicht mehr weiter, hoffe auf Hilfe.
Hier ist meine vorhandene CSV-Datei (kleiner Auszug):


A B C D
1. 00:00 ; 0.10 ; 0.05 ; 0.01
2. 00:01 ; 0.03 ; 0.04 ; 0.00
3. 00:02 ; 0.01 ; 0.03 ; 0.00
4. 00:03 ; 0.05 ; 0.04 ; 0.00
5. 00:04 ; 0.02 ; 0.03 ; 0.00
...
...
...

Ich möchte NUR die Werte aus Spalte 'A' entnehmen und in Text-Datei bzw. gleich in ein Double-Array speichern.
Anschließend die Werte aus B, C und letztendlich aus D entnehmen.

Wie mach ich das? Habe schon (BufferedReader und ArrayList probiert, aber ich kriege es nicht hin...)

Ich bitte um Hilfe. Lieben Dank im Vorraus!

Mit freindlichen Grüßen Andre1978
 

FArt

Top Contributor
Das ist keine sinnvolle CSV Datei. Was ist denn der Separator für die Spalten?

Lies die Datei zeilenweise ein, suche den Index der ersten beiden ";" und nimm den Substring dazwischen, parse ihn als Double und speicher ihn in ein Array (oder erst Liste, die wächst dynamisch).

Ist eine nette Fingerübung ;-)
 
S

SlaterB

Gast
mit BufferedReader bekommst du Zeilen, diese nach ; splitten,

wenn irgendwas nicht bekannt ist solltest du schon genauere Fragen als 'kriege ich nicht hin' stellen,

und wenn du so eine genauere Frage wie 'wie kann ich mit BufferedReader einzelne Zeilen einlesen?' erstmal hast,
dann kannst du auch gleich versuchen, die Frage fast 1 zu 1 in google einzutippen,
evtl. Füllwörter entfernen und 'java' hinzufügen
 

Andre1978

Mitglied
Hallo FArt und SlaterB,
hier ein kleiner Auszug meiner Klasse:

package Diagramm;
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class logfile {
public static void main(String[] args){
LineNumberReader file;
String line;
FileWriter writer;
Calendar cal = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat("dd.MM.yyyy");
String datum = (sdf.format(cal.getTime()));
Calendar cal3 = Calendar.getInstance();
SimpleDateFormat sdf3 = new SimpleDateFormat("yyyyMMdd");
String datum3 = (sdf3.format(cal3.getTime()));
String datei = ("load."+datum+".csv");
try{
file = new LineNumberReader( new FileReader("G:/AFUSS/Workspace/load."+datum3+".log"));
writer = new FileWriter("G:/AFUSS/Workspace/load."+datum+".csv");
while ((line = file.readLine()) != null){
//String c = (line.replaceAll(",", ";"));
String c = (line.replace(",", ";"));
writer.write(Character.LINE_SEPARATOR);
writer.write(c);
System.out.println(c);// ---> Diese Ausgabe dient nur zur Kontrolle.
}
System.out.println("\nDie Datei: "+datei+" wurde erfolgreich erstellt!");
writer.close();
}
catch (IOException e){
System.out.print("Die Datei konnte nicht gefunden werden!");
}
}
}
 
S

SlaterB

Gast
und auf die bisherigen Tipps willst du dabei nicht näher eingehen
oder irgendwie erklären, was dein Programm mit der Sache zu tun haben könnte?

z.B. die log-Datei und die csv-Datei dort, die csv-Datei wird mit einem Writer anscheinend erst geschrieben,
ich dachte es geht um das Einlesen einer csv-Datei?
 

Andre1978

Mitglied
HIER MEINE LÖSUNG: DANKE NOCHMAL !!!!

package Diagramm;
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class logfile {
public static void main(String[] args){
LineNumberReader file;
String line;
FileWriter writer;
Calendar cal = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat("dd.MM.yyyy");
String datum = (sdf.format(cal.getTime()));
Calendar cal3 = Calendar.getInstance();
SimpleDateFormat sdf3 = new SimpleDateFormat("yyyyMMdd");
String datum3 = (sdf3.format(cal3.getTime()));
String datei = ("load."+datum+".csv");
try{
file = new LineNumberReader( new FileReader("G:/AFUSS/Workspace/load."+datum3+".log"));
writer = new FileWriter("G:/AFUSS/Workspace/load."+datum+".csv");
while ((line = file.readLine()) != null){
String c = (line.replaceAll(",", ";"));
writer.write(Character.LINE_SEPARATOR);
writer.write(c);
String[] spalten = c.split(";");
String spA = (spalten[0]);
String spB = (spalten[1]);
String spC = (spalten[2]);
String spD = (spalten[3]);

System.out.println(spA); // HUIJUIHUI-Alles klar :)
}
System.out.println("\nDie Datei: "+datei+" wurde erfolgreich erstellt!");
writer.close();
}
catch (IOException e){
System.out.print("Die Datei konnte nicht gefunden werden!");
}
}
}
 

Andre1978

Mitglied
Hallo nochmal liebe Forem-Besucher, erstmal vielen Dank für die schnelle und sehr hilfreiche Hilfe.
Ich habe noch ein (für einen für Euch wohl eher kleines Problem),
und zwar:

Ich möchte ein "String Array" in ein Double Array umwandeln, damit ich damit weiterarbeiten kann. Ich bitte um Hilfe zur Realisierung.

Danke im Vorraus. Gruß Andre1978
 
S

SlaterB

Gast
neues Array gleicher Größe erstellen,
in einer Schleife jeden Wert parsen, z.B. mit Double.parseDoube() und ins neue Array schreiben
 

Andre1978

Mitglied
TagesSicht[] ts = new TagesSicht[laenge];
while ((line = file.readLine()) != null){

double ts = Double.parseDouble(spA);
}
 

Andre1978

Mitglied
Das ist mein vorhandenes (nicht mehr änderbares double-Array names w)

Hier mein vorhandenes String-Array:

String spA = (spalten[0]);

Nun möchte ich zu einem double-Array umwandeln:

double w[]={ hier möchte ich meine 'Spalte A' reinbekommen };

please help. Thanks
 
S

SlaterB

Gast
das Wiederholen der Frage trifft auf meine beiden Anmerkungen kaum zu, oder?
naja, vielleicht weiß wer anders weiter..
 

Andre1978

Mitglied
Hier nochmal mein kompletter Code:

package Diagramm;

import java.awt.*;
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class TagesSicht extends Frame{
private static final long serialVersionUID = 1L;
Leinwand zeich;
double werte[];
String texte[];
String beschriftungXAchse;
String beschriftungYAchse;
int i = 0;
int diagrammTyp;
public static void main (String[] args){
LineNumberReader file;
String line;
FileWriter writer;
Calendar cal = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat("dd.MM.yyyy");
String datum = (sdf.format(cal.getTime()));
Calendar cal3 = Calendar.getInstance();
SimpleDateFormat sdf3 = new SimpleDateFormat("yyyyMMdd");
String datum3 = (sdf3.format(cal3.getTime()));
// String datei = ("load."+datum+".csv");
try{
file = new LineNumberReader( new FileReader("G:/AFUSS/Workspace/load."+datum3+".log"));
writer = new FileWriter("G:/AFUSS/Workspace/load."+datum+".csv");
System.out.println("Zeile:\tZeit:\t\t\tWert-1\t\t\tWert-2\t\t\tWert-3\n");
while ((line = file.readLine()) != null){
String c = (line.replaceAll(",", ";"));
writer.write(Character.LINE_SEPARATOR);
writer.write(c);
String[] spalten = c.split(";");
int laenge = file.getLineNumber();
String spA = (spalten[0]);String spB = (spalten[1]);
String spC = (spalten[2]);String spD = (spalten[3]);


TagesSicht[] ts = new TagesSicht[laenge];
while ((line = file.readLine()) != null){

// HIER MUSS DAS GESCHEHEN,WAS DU MIT GERATEN HAST,ABER WIE???
}
System.out.println(laenge+"\t"+spA+"\t\t\t"+spB+"\t\t\t"+spC+"\t\t\t"+spD);
}
System.out.println("\nDie Datei: "+datei+" wurde erfolgreich erstellt!");
writer.close();
}
catch (IOException e){
System.out.print("Die Datei konnte nicht gefunden werden!");
}
double w[] = {23000,25000,27000,25000,23000,21000,19000,21000,23000,25000,27000,29000,31000,33000,35000,
37000,39000,41000,43000,45000,47000,49000,51000,53000};
String b[] = {"1","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18",
"19","20","21","22","23","24"};
TagesSicht ms = new TagesSicht(w,b,"Minuten","Werte",0);
ms.show();
}
/** Konstruktor */
public TagesSicht(double[] diagrWerte, String[] diagrTexte, String xBeschrift, String yBeschrift, int diagrTyp){
//Werte setzen
werte = diagrWerte;
texte = diagrTexte;
beschriftungXAchse = xBeschrift;
beschriftungYAchse = yBeschrift;
diagrammTyp = diagrTyp;
init();
}
public void init(){
setTitle("Diagramm-Monatssicht");
Button weg = new Button("Fenster schließen");
weg.addActionListener(new FensterZu());
zeich = new Leinwand();
Panel unten=new Panel();
unten.setBackground(Color.gray);
unten.setLayout(new FlowLayout());
unten.add(weg);
setLayout(new BorderLayout());
add(zeich,BorderLayout.CENTER);
add(unten,BorderLayout.SOUTH);
pack();
}
public class Leinwand extends Canvas{
private static final long serialVersionUID = 1L;
public void paint(Graphics g){
//Zeichenbefehle
g.setFont(new Font("Tahoma", Font.PLAIN, 9));
g.translate(100,330);
int abstand = 0;
int xAbstand;
if(werte.length > 1)
xAbstand = (int)Math.round(400D / (werte.length - 1));
else
xAbstand = 0;
//senkrechte Linien
g.setColor(new Color(255, 255, 255));
int xWerte[] = new int[werte.length + 2];
for(i = 0; i < werte.length; i++){
g.drawLine(i * xAbstand, 0, i * xAbstand, -250);
xWerte = i * xAbstand;
}
xWerte = xWerte[i - 1];
xWerte[i + 1] = 0;
//y-Werte
//max berechnen
double max = werte[0];
for(i = 0; i < werte.length; i++)
max = Math.max(max, werte);
if(max < 0 ) max = 0; //sonst Fehler
double min = werte[0];
for(i = 0; i < werte.length; i++)
min = Math.min(min, werte);
double einheitenJePixel;
if(min < 0)
einheitenJePixel = (max+Math.abs(min)) / 250D;
else
einheitenJePixel = max/250D; //Einheiten je 1px ausrechnen
//wenn es negative Werte gibt --> x-Achse entsprechend verschieben
if(min < 0)
g.translate(0,(int)Math.round(min / einheitenJePixel));
//Beschriftungen
///max neu ausrechnen, falls negativ
for(i = 0; i < werte.length; i++)
max = Math.max(max, werte);
g.setColor(Color.black);
g.drawString("" + max, - 45, (int)((-1) * max / einheitenJePixel));
g.drawString("" + min, - 45, (int)((-1) * min / einheitenJePixel));
//y-Werte aus Werte/eJePx berechnen -1
int yWerte[] = new int[werte.length + 2];
for(i = 0; i < werte.length; i++)
yWerte = (-1) * (int)Math.round(werte / einheitenJePixel);
yWerte = 0;
yWerte[i + 1] = 0;
g.setColor(Color.orange);
abstand = (int)Math.round((400D-15D) / werte.length);
if(abstand < 2) abstand = 5; //mind. 1px Balkenbreite, mind. 1px Abstand zwischen Balken
xWerte[0] = 10;
for(i = 1; i < werte.length; i++)
xWerte = xWerte[i-1] + abstand;
for(i = 0; i < werte.length; i++){
if(yWerte > 0)
g.fill3DRect(xWerte, 0, abstand / 2, Math.abs(yWerte), true);
else
g.fill3DRect(xWerte, yWerte, abstand / 2, Math.abs(yWerte), true);
}
//Beschriftungen
g.setColor(Color.black);
for(i = 0; i < werte.length; i++){
int q = 15;
if(werte >= 0) q = 15; else q = -5;
g.drawString(texte ,xWerte, q);
}
//Koordinatenkreuz
//x-Achse
g.drawLine(-5, 0, 410, 0);
g.drawLine(405, -2, 410, 0);
g.drawLine(405, 2, 410, 0); //Pfeilspitze
g.drawString(beschriftungXAchse, 415, 0);
//wenn es negative Werte gibt --> x-Achse entsprechend verschieben
if(min < 0)
g.translate(0, (-1) * (int)Math.round(min / einheitenJePixel));
//y-Achse
g.drawLine(0, 5, 0, -270);
g.drawLine(-2, -265, 0, -270);
g.drawLine(2, -265, 0, -270); //Pfeilspitze
g.drawString(beschriftungYAchse, -25 ,-275);
}
public Dimension getMinimumSize(){ //Fenstergröße
return new Dimension(600, 400);
}
public Dimension getPreferredSize(){
return getMinimumSize();
}
}
//Methoden zum Setzen der Werte für das Diagramm
public void setBeschriftungXAchse(String xBeschriftung){
beschriftungXAchse = xBeschriftung;
}
public void setBeschriftungYAchse(String yBeschriftung){
beschriftungYAchse = yBeschriftung;
}
public void setWerte(double [] diaWerte){
werte = diaWerte;
}
public void setTexte(String [] diaTexte){
texte = diaTexte;
}
}


Ich muss das erzeugte String Array in ein Double-Array umwandeln........ Brauch dringend Hilfe. Bitte
 
S

SlaterB

Gast
noch ein kostenloser Tipp:

vergiss vorerst dein ellenlanges Programm und arbeite mit
Code:
public class Test
{
    public static void main(String[] args)
    {
        String[] x = new String[] {"2.3","4.3"};
    }
}

solange du aber zu konkreten Tipps wie
"double[] erstellen, Schleife, Strings einzeln umwandeln"
nur
"ich nix wissen, bitte fertige Lösung" schreibst,
werde ich persönlich nicht deine Arbeit erledigen
 
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