Apache POI копирует одну строку из файла Excel в другой новый файл Excel - PullRequest
0 голосов
/ 19 декабря 2018

Я использую JAVA 8 и Apache POI 3.17.У меня есть файл Excel, и я хочу сохранить только несколько строк и удалить другие.Но в моем Excel 40K строк, и их удаление по одной довольно длинное (почти 30 минут: /)

Поэтому я пытаюсь изменить свой способ сделать это.Теперь я думаю, что лучше брать только те строки, которые мне нужны, в исходном коде Excel и копировать в другой новый.Но то, что я пробовал до сих пор, неэффективно.

У меня есть все строки и я хочу сохранить их в списке.Но это не работает, и создайте мне пустой Excel:

public void createExcelFileFromLog (Path logRejetFilePath, Path fichierInterdits) throws IOException {

Map<Integer, Integer> mapLigneColonne = getRowAndColumnInError(logRejetFilePath);

Workbook sourceWorkbook = WorkbookFactory.create(new File(fichierInterdits.toAbsolutePath().toString()));

Sheet sourceSheet = sourceWorkbook.getSheetAt(0);

List<Row> listLignes = new ArrayList<Row>();

// get Rows from source Excel
for (Map.Entry<Integer, Integer> entry : mapLigneColonne.entrySet()) {
    listLignes.add(sourceSheet.getRow(entry.getKey()-1));
}

// The new Excel
Workbook workbookToWrite = new XSSFWorkbook();
Sheet sheetToWrite = workbookToWrite.createSheet("Interdits en erreur");

// Copy Rows
Integer i = 0;
for (Row row : listLignes) {
    copyRow(sheetToWrite, row, i);
    i++;
}

FileOutputStream fos = new FileOutputStream(config.getDossierTemporaire() + "Interdits_en_erreur.xlsx");
workbookToWrite.write(fos);
workbookToWrite.close();
sourceWorkbook.close();
}

private static void copyRow(Sheet newSheet, Row sourceRow, int newRowNum) {

Row newRow = newSheet.createRow(newRowNum);
newRow = sourceRow;
}

РЕДАКТИРОВАТЬ: Изменить метод copyRow лучше, но дата имеет странный формат и пустые ячейки из исходной строки исчезли.

private static void copyRow(Sheet newSheet, Row sourceRow, int newRowNum) {

    Row newRow = newSheet.createRow(newRowNum);
    Integer i = 0;

    for (Cell cell : sourceRow) {

        if(cell.getCellTypeEnum() == CellType.NUMERIC) {
            newRow.createCell(i).setCellValue(cell.getDateCellValue());
        } else {
            newRow.createCell(i).setCellValue(cell.getStringCellValue());
        }
        i++;
    }
}

РЕДАКТИРОВАТЬ 2: оставить пустую ячейку

private static void copyRow(Sheet newSheet, Row sourceRow, Integer newRowNum, Integer cellToColor) {

    Row newRow = newSheet.createRow(newRowNum);
    //Integer i = 0;

    int lastColumn = Math.max(sourceRow.getLastCellNum(), 0);

    for(int i = 0; i < lastColumn; i++) {
        Cell oldCell = sourceRow.getCell(i, Row.MissingCellPolicy.RETURN_BLANK_AS_NULL);

        if(oldCell == null) {
            newRow.createCell(i).setCellValue("");
        } else if (oldCell.getCellTypeEnum() == CellType.NUMERIC) {
            newRow.createCell(i).setCellValue(oldCell.getDateCellValue());
        } else {
            newRow.createCell(i).setCellValue(oldCell.getStringCellValue());
        }
    }
}
...