Java xlsx zu csv

Lia

Bekanntes Mitglied
Hi

Versuche eben eine xlsx zu einer Csv umzuwandeln.

Beim umwandeln werden aber alle leeren Zellen ignoriert. Dadurch tut er es nicht richtig umwandeln, weil er die Zellen nach links verschiebt und dadurch eine falsche Ausgabe generiert.

Habe in der Spalte

switch(cellType){

...

case : BLANK
sb.append(";;");
}

Ignoriert das total.
 
K

kneitzel

Gast
Kannst Du da mehr Details nennen? Was für Libraries nutzt Du?

Und wenn er dies ignoriert: Mal im Debugger geschaut? Evtl. ist cellType nicht BLANK sondern irgend etwas anderes?
 

Lia

Bekanntes Mitglied
Hi @kneitzel :)

ne es ist leer also blank habe auch Mal eine xlsx mit leeren Zellen erstellt. Und ein System.out eingebaut aber er geht da erst gar nicht rein.
 
K

kneitzel

Gast
@Lia Damit hast Du aber weiter keine weiteren Details genannt. Wir wissen somit weiterhin nicht, was cellType genau ist. Wenn er aber nicht bei case: BLANK rein geht, dann ist es mit relativ große Wahrscheinlichkeit wohl nicht BLANK. Da kann man aber im Debugger meist recht gut nachvollziehen.

Zeig doch den ganzen Code, der da wichtig ist, so dass wir Dir helfen können. So mit Glaskugel und so funktioniert das hier leider nicht.

Oder Du versuchst Dich an einer fertigen Lösung wie z.B. von @mihe7 vorgeschlagen.
 
X

Xyz1

Gast
Siehst Du einmal hier:

Java:
                // Open the workbook
                this.openWorkbook(excelFile);
    
                // Convert it's contents into a CSV file
                this.convertToCSV();
    
                // Build the name of the csv folder from that of the Excel workbook.
                // Simply replace the .xls or .xlsx file extension with .csv
                destinationFilename = excelFile.getName();
                destinationFilename = destinationFilename.substring(
                        0, destinationFilename.lastIndexOf(".")) +
                        ToCSV.CSV_FILE_EXTENSION;
    
                // Save the CSV file away using the newly constricted file name
                // and to the specified directory.
                this.saveCSVFile(new File(destination, destinationFilename));

Umgekehrt ist es viel schwerer... klar!
 

Lia

Bekanntes Mitglied
@kneitzel

while(cellIterator.hasNext()){
Cell cell=cellIterator.next();
switch(cell.getCellType()){
case STRING:...

case BLANK:
sb.append(";");
}
}

So sieht der Abschnitt aus.
 

mihe7

Top Contributor
Sowohl in der Antwort von z. B. @Tobias-nrw als auch von mir wird nicht via CellIterator über die Zellen iteriert. Probier es doch mal so:

Java:
            int lastCellNum = row.getLastCellNum();
            for(int i = 0; i <= lastCellNum; i++) {
                cell = row.getCell(i);
                if (cell == null) {
                    sb.append(";");
                } else switch(cell.getCellType()) {
                     case STRING: ...
                }
            }
 
K

kneitzel

Gast
Also gut, es scheint also so zu sein, dass Du die POI API von Apache verwendest. (Eine Aussage, die hilfreich gewesen wäre).

Bezüglich Iterator:
http://poi.apache.org/components/spreadsheet/quick-guide.html#Iterator
"Note that a rowIterator and cellIterator iterate over rows or cells that have been created, skipping empty rows and cells."

Und direkt danach dann ein Absatz, wie man auch leere Zellen bekommt.

Der darin wichtige Punkt ist, dass man getCell(i, MissingCellPolicy) benutzt, um eine leere Zelle zu bekommen. Aber die leeren Zellen musst Du ja nicht prüfen, denn das cell==null sollte schon die notwendige Prüfung sein.
 
K

kneitzel

Gast
Du warst nicht angesprochen...
Was für eine tolle Aussage von Dir schon wieder. Ist es Dir jetzt peinlich, dass Du dies nicht selbst gesehen hast? Und dass ausgerechnet ich Dich darauf aufmerksam machen musste? Oder was ist das jetzt für eine tolle Reaktion?

Wenn Du nur eine Antwort von @mihe7 haben willst, dann schreib ihm eine PN. Oder lebe schlicht damit, dass auch Andere Dir antworten. (Und nein, etwas zu übersehen muss einem nicht peinlich sein. So Kleinkind-Verhalten aber schon!)
 
K

kneitzel

Gast
Habe ich etwas falsches gesagt

Nein, alles ok. Für mich war einfach nur nicht sofort klar, welche Library Du nutzt. Apache POI ist wohl eine sehr verbreitete Library, aber es gibt eben auch noch andere. Daher hatte ich da etwas nachgehakt und es dann aus dem Kontext am Ende geschlossen.

Und irgendwelche "Zickereien" zwischen @Tobias-nrw und mir ignorierst Du am Besten. Da geht es auch nicht um Dich oder Deine Themen...
 

Lia

Bekanntes Mitglied
Achso ok alles klar ich probiere es später Mal mit cell==null zu implementieren und schicke es Mal hier rein wenn es wieder nicht funktioniert :oops::D
 

Lia

Bekanntes Mitglied
@kneitzel habe es damit probiert :

wb.setMissingCellPolicy(MissingCellPolicy.RETURNNULLANDBLANK);

und habe den Zelltyp BLANK trotzdem ganz normal implementiert aber trotzdem ignoriert der Compiler die leere Zelle und verschiebt die Zellen ..
 
K

kneitzel

Gast
In dem Link stand es aber auch anders :)

Also in der Dokumentation, die ich verlinkt habe, wurde die Policy direkt im getCell benutzt und kein CellIterator verwendet. Der CellIterator ist diesbezüglich limitiert ("The CellIterator will only return the cells defined in the file, which is largely those with values or stylings, but it depends on Excel.")

Ich habe mal den Code, so wie er in der Dokumentation war, genommen und habe da einen Part noch angepasst, da Du ja scheinbar kein null als Cell haben willst (zweite Schleife):

Java:
package de.kneitzel.apachepoi;

import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.IOException;
import java.util.Iterator;

public class XlsxTest {
    public static void main(String[] args) throws IOException {
        XSSFWorkbook workbook = new XSSFWorkbook("c:/Projects/javatests/test.xlsx");
        Sheet datatypeSheet = workbook.getSheetAt(0);

        // Decide which rows to process
        int rowStart = datatypeSheet.getFirstRowNum();
        int rowEnd = datatypeSheet.getLastRowNum();
        System.out.println("Rows: " + rowStart + " - " + rowEnd);

        //  Handle empty cells with null
        System.out.println("Using RETURN_BLANK_AND_NULL");
        for (int rowNum = rowStart; rowNum <= rowEnd; rowNum++) {
            Row r = datatypeSheet.getRow(rowNum);
            if (r == null) {
                // This whole row is empty
                // Handle it as needed
                continue;
            }

            int lastColumn = Math.max(r.getLastCellNum(), 1);

            for (int cn = 0; cn < lastColumn; cn++) {
                Cell c = r.getCell(cn, Row.MissingCellPolicy.RETURN_BLANK_AS_NULL);
                if (c == null) {
                    System.out.println("Empty Cell!");
                } else {
                    System.out.println(c.getAddress().toString() + ": " + c.getCellType().toString());
                }
            }
        }

        // Handle empty cells als BLANK cell.
        System.out.println("Using CREATE_NULL_AS_BLANK");
        for (int rowNum = rowStart; rowNum <= rowEnd; rowNum++) {
            Row r = datatypeSheet.getRow(rowNum);
            if (r == null) {
                // This whole row is empty
                // Handle it as needed
                continue;
            }

            int lastColumn = Math.max(r.getLastCellNum(), 1);

            for (int cn = 0; cn < lastColumn; cn++) {
                Cell c = r.getCell(cn, Row.MissingCellPolicy.CREATE_NULL_AS_BLANK);
                System.out.println(c.getAddress().toString() + ": " + c.getCellType().toString());
            }
        }
    }
}

Der erste Part entspricht damit auch dem, was @mihe7 geschrieben hat. Leere Cell wird halt als null zurück gegeben. So man da aber eine BLANK Cell haben will, dann kann man halt bei getCell die RowMissingCellPolicy.CREATE_NULL_AS_BLANK verwenden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben