Frage zu Javacsv/Csvreader: Zeilenanzahl

klofisch

Mitglied
Hallo,

hat vielleicht schon jemand mit Javacsv was gemacht? Ich möchte gern die Anzahl der Zeilen eines CSV-Sheets augeben lassen.


Danke
Peter
 

parabool

Bekanntes Mitglied
laut Api getHeaderCount() , vorher readHeaders() aufrufen.

CsvReader (JavaCSV API)

Edit: ok, Anzahl der Zeilen war gemeint, nicht der Spalten. :D
Geht wohl nicht anders als die csv Datei durchlaufen und die Zeilen zählen.
 
Zuletzt bearbeitet:

parabool

Bekanntes Mitglied
hmm, ist mir gerade eingefallen: Du kannst aus der Größe der Datei und der durchschnittlichen
Länge einer Zeile die ungefähre Anzahl an Zeilen errechnen.

Hat bei mir gut geklappt (Fortschrittsanzeige beim Laden einer sehr grossen csv.Datei)
 
G

Gast2

Gast
@parabool
Wie kommst du an die durchschnittliche Länge einer Zeile? Wenn du die schätzt kommt du nicht auf die exakte Anzahl der Zeilen, wenn du die ausrechnen willst bist du zwangsläufig schon alle Zeilen durchgegangen ;)

@TO:
Wenn die Datei nicht allzu groß ist würd ich die Datensätze inkrementell lesen und nen Zähler hochlaufen lassen.
 

parabool

Bekanntes Mitglied
Meine natürlich den "geschätzten Durschnitt" (den tatsächlichen auszurechnen wäre in der Tat absurd :D) .
Wenn sich das das Format nicht ändert hat man den ev. schon. Oder die ersten 100 Zeilen einlesen
und den Durchschnitt bilden, vorausgesetzt die Länge der Zeilen ist innerhalb der Datei ungefähr gleich verteilt.
Die tatsächl. Anzahl wird da nicht rauskommen - klar. ;)

Habe es bei der Fortschrittsanzeige auch etwas anders gemacht:
- Max. der Progressbar auf Grösse der Datei gesetzt (ev. mit Faktor)
- Value der Progressbar bei jeden Schritt um Grösse der aktuell gelesen Zeile erhöhen
 

klofisch

Mitglied
danke für die Antworten. Bin jetzt am Probieren mit jCSV von Eike.

bekomme ich die Fehlermeldung "The method newDefaultReader(Reader) is undefined for the type CSVReader"
wenn ich das Bsp. von der Webseite benutze.

Code:
Reader reader = new FileReader("data.csv");

CSVReader<String[]> csvPersonReader = CSVReaderBuilder.newDefaultReader(reader);
List<String[]> persons = csvPersonReader.readAll();
 
G

Gast2

Gast
Auf der Startseite stand tatsächlich noch ein leicht altes Codebeispiel, ist mittlerweile korrigiert.

Der Code den du hier in deinem Post gepostet hast sollte aber funktionieren. Die Anzahl der Einträge (wenn du die Einträge später nichtmehr brauchst!) würde ich dann so auslesen:
Java:
CSVReader<String[]> csvPersonReader = CSVReaderBuilder.newDefaultReader(reader);

int counter = 0;
for (String[] row : csvPersonReader) {
	counter++;
}
System.out.printf("Einträge: %s", counter);
 

klofisch

Mitglied
Danke für die Info, der Fehler ist weg.

zwischenzeitlich versuche ich die Ergebnisse in ein zweidimensionales Array zu konvertieren. Sicher etwas umständlich, aber als neuling....

Ich bekomme dabei allerdings folgende Fehlermeldung nachdem ersten Datensatz

Code:
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 1
	at CsvTest01.main(CsvTest01.java:34)


Code:
		String[] sResult;
		String[][] saReturn = { { "", "", "", "", "", "" } };
		try {
			Reader reader = new FileReader("./data/test1.csv");
			CSVReader<String[]> csvParser = CSVReaderBuilder
					.newDefaultReader(reader);
			List<String[]> laEntries = csvParser.readAll();
			System.out.println("List length: " + laEntries.size());

			for (int iRow = 0; iRow < laEntries.size(); iRow++) {
				sResult = laEntries.get(iRow);
				System.out.println("sResult " + sResult.length);
				for (int iCol = 0; iCol < sResult.length; iCol++) {
					System.out.println("iRow " + iRow);
					System.out.println("iCol " + iCol);
					System.out.println(sResult[iCol].toString());
					saReturn[iRow][iCol] = sResult[iCol].toString(); //Fehler wird hier produziert
				}
				
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

ich benutze diese Demodaten:

Code:
1;Dirk;Fleischhacker;23;m
2;Paul;Panzer;18;m
3;Christina;Kaltwasser;19;f
4;Angelika;Sauer;19;f
5;Susanne;Bloomberg;20;f
6;Maik;Rosenberg;22;m
7;Tom;Baumgartner;23;m
8;Paula;Schulz;17;f

Woran liegts?
 
Zuletzt bearbeitet:
G

Gast2

Gast
Wofür genau brauchst du denn nen 2D Array? Tuts nicht auch die List<String[]> ?

Zu deinem Fehler:
Das saReturn Array ist zu klein, du legst das mit ner Größe von 1 an. Richtiger wäre sowas:
Java:
saReturn = new String[laEntries.size()][5];
Aber wie gesagt, wenns keinen wirklich guten Grund gibt das in nen 2D Array zu wandeln, dann benutz die Liste.

Und wenns doch nen 2D Array werden soll, dann mach die Umwandlung so:
Java:
String[][] result= list.toArray(new String[laEntries.size()][5]);
 
V

vanny

Gast
Schreib dir doch gleich einen Datentyp, der einen Datensatz als Objekt vorhält.
Diese Instanzen legste dann einfach in einer Liste oder Map ab.
Auch wenn du Neuling bist ist das kein Grund sich da durchzuwurschteln ;P

Könnte etwa so aussehen:
Java:
public class CSVEintrag {
	
	private int id, age;
	private String firstName, lastName, gender;
	
	
	public CSVEintrag(int id, String firstName, String lastName, int age, String gender){
		setId(id);
		setFirstName(firstName);
		setLastName(lastName);
		setAge(age);
		setGender(gender);
	}
	
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public String getFirstName() {
		return firstName;
	}
	public void setFirstName(String firstName) {
		this.firstName = firstName;
	}
	public String getLastName() {
		return lastName;
	}
	public void setLastName(String lastName) {
		this.lastName = lastName;
	}
	public String getGender() {
		return gender;
	}
	public void setGender(String gender) {
		this.gender = gender;
	}

}
 

klofisch

Mitglied
@Eike: Beim Ausprobieren konnte ich keinen Unterschied zwischen deinen Vorschlägen feststellen.

Ich brauche das um es in einem JTable darzustellen. Ich brauch dieses String-Array für das defaultdatamodel für ein JTable,

@Vanny
Merk ich mir für später:)

Danke erstmal :)
 

klofisch

Mitglied
Ich habe mich jetzt für opencsv entschieden. Nach ein bisschen rumprobieren und stricken geht schon mal bisschen was. Aber es gibt auch wieder neue Fragen.
Hier habe ich ein kleines problem mit Mein Problem ist noch das Trennzeichen. Gibt es eine Möglichkeit, dieses automatisch zu erkennen? Komma-getrennte Datensätze werden richtig erkannt, aber nicht mit Semikolon-getrennte.
 

parabool

Bekanntes Mitglied
Defaultseparator ist ja auch ','
mit Konstruktur
Java:
CSVReader(Reader reader, char separator)
kannst das Trennzeichen festlegen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben