Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden. Du solltest ein Upgrade durchführen oder ein alternativer Browser verwenden.
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.
@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.
// 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));
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.
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!)
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...
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.