Hallo, ich muss eine Excel-Tabelle einlesen. Aus der Tabelle sollen jeweils die ersten zehn Werte aus der jeweiligen Spalte ausgelesen werden. Also dachte ich mir, ich lege ein Array an und speichere die Daten in das Array. Das Problem: Die Excel-Tabellen haben keine konstante Spaltenanzahl. Kann man Arrays dynamisch anlegen. Bekommt der Arrayname einen Index oder wie kann man das Problem lösen. Die Arraygröße soll immer gleich groß sein? Gruß Tom
http://www.dpunkt.de/java/Referenz/Das_Paket_java.util/59.html Die Klasse Vector aus dem java.util. Baukasten implementiert ein dynamisches Array, das Objekte speichern kann. Die Größe des Vektors wird automatisch an die benötigte Größe angepaßt. Denkbar wäre ein Vector, der für jede eingelesene Zeile einen Vector hat, der die unterschiedlich vielen Spalten(Objekte) hält. pseudocode: neuer zeilenvector. für alle zeilen: neuer spaltenvector. für 10 spalten: spaltenvector.add( spalte ) zeilenvector.add( spaltenvector ) Bye, Seb
uups, du möchtest ja nur eine spalte auslesen. denke sollt dir trotzdem weiterhelfen :) Bye, Seb
Hallo, danke. Nene, ich möchte alle Spalten auslesen. Nur mal hat die Excel-Datei 3 mal 4 mal 5 ... Spalten. Tom
aah :) mensch, so früh am morgen.. für die 10 zeilen pro spalte kannst ein statisches array nehmen. für jede spalte fürgst beim dynamischen vector ein statisches array (quasi der zeiger darauf, sieht man bei java aber nicht) hinzu. jetzt aber :) neuer spaltenvector. für alle spalten: neues zeilenarray für 10 elemente. für 10 zeilen: zeilenarray.add( spalte ) spaltenvector.add( zeilenarray ) Bye, Seb
Entweder ArrayList oder: int zeilen = 10; Object[][] exel = new Object[zeilen][0] for(int i = 0;i<zeilen;i++) { int spalten = getAnzahlSpalten(); Object[] spaltenArray = new Object[spalten]; //Lese Spalten... exel[i] = spaltenArray; }
1 | Vector<Vector<String>> vecTable = new Vector<Vector<String>>(); |
2 | |
3 | for (int iRow=0; iRow<numberOfRows; iRow++) { |
4 | Vector<String> vecRow = new Vector<String>(); |
5 | for (int iCol=0; iCol<numberOfCols; iCol++) { |
6 | vecRow.add( rowData[iCol] ); |
7 | }
|
8 | |
9 | vecTable.add(vecRow); |
10 | }
|
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.