Написание файла Excel занимает около 30 минут, чтобы записать 50 тыс. Записей - PullRequest
0 голосов
/ 06 сентября 2018

Для записи только 50 тыс. Записей требуется около 30 минут. Кто-нибудь может подсказать, в чем может быть проблема?

Это код:

public static File writeInvalidInputExcelFile(final List<RawInputData> invalidInputRecords,
                                              @NonNull final List<String> headers,
                                              @NonNull final String invalidInputFilePath) throws IOException, IllegalAccessException {
    OutputStream outStream = null;
    final File invalidRecordFile = new File(invalidInputFilePath);
    try {
        final SXSSFSheet invalidRecordsSheet = ExcelUtility.createWorkBookWithHeader("invalid records",
                0, headers);
        int rowCount = 1;
        for (final RawInputData invalidinputRecord : invalidInputRecords) {

            ExcelUtility.writeEntriesForEachCellInTheGivenRow(invalidinputRecord,
                    rowCount++, invalidRecordsSheet);
        }
        outStream = new FileOutputStream(invalidInputFilePath, true);
        invalidRecordsSheet.getWorkbook().write(outStream);
        invalidRecordsSheet.getWorkbook().close();
        outStream.flush();
        return invalidRecordFile;
    } catch (RuntimeException e) {
        /////// check where to handle (SEV2 or SEV3.)
        log.error("failed to generate invalid recod files");
        throw e;
    }
    finally {
        if(outStream!=null)
        {
            outStream.close();
        }
    }
}

/**
 * Method to write the entry in each cell for the given row.
 *
 * @throws IllegalArgumentException -IllegalArgumentException
 */
public static void writeEntriesForEachCellInTheGivenRow(final List<String> invalidInput, final int rowCount,
                                                        @NonNull final SXSSFSheet xssfSheet) throws IllegalArgumentException {
    //log.info("writing record to excel file {} invalidInput.toString()");
    final SXSSFRow xssfRow = xssfSheet.createRow(rowCount);
    int cell = 0;
    for (final String fieldValue : invalidInput) {
        final SXSSFCell xssfCell =xssfRow.createCell(cell);
        xssfCell.setCellValue(fieldValue);
        xssfSheet.autoSizeColumn(cell);
        cell++;
    }
    //log.info("end writing record to excel file");
}
...