1

我正在使用 JXL 编写一个 50000 行和 30 列的 excel 文件。我的代码如下所示:

for (int j = 0; j < countOfRows; j++) {

myWritableSheet.addCell(new Label(0, j, myResultSet.getString(1), myWritableCellFormat));

myWritableSheet.addCell(new Label(1, j, myResultSet.getString(2), myWritableCellFormat));

.....

.....

}

在编写单元格时,程序变得越来越慢

最后在第 25000 行附近出现以下错误:

线程“Thread-3”java.lang.OutOfMemoryError 中的异常:jxl.write.biff.WritableSheetImpl.addCell(WritableSheetImpl.java:951) 处 jxl.write.biff.WritableSheetImpl.getRowRecord(WritableSheetImpl.java:984) 处的 Java 堆空间) 在 KLL.ConverterMainFrame$exportToXLSBillRightsThread.run(ConverterMainFrame.java:6895)

在 Java 中处理内存总是很困难的。

在这种情况下,它似乎是 jxl 的问题。

有没有办法写入文件,清除内存并继续每 1000 个单元格写入单元格?

这是一个好主意还是您会提出什么其他解决方案?

4

2 回答 2

6

JExcel FAQ有一些建议,包括上面的 Curtis 的想法。

如果您不介意性能损失,您可以使用临时文件而不是全部在内存中进行

WorkbookSettings s = new WorkbookSettings();  
s.setUseTemporaryFileDuringWrite(true);  
WritableWorkbook ws = Workbook.createWorkbook(new File("someFile.xls"),s); 
于 2010-07-03T20:15:03.557 回答
1

提高 VM 的可用内存(使用 -Xms 和 -Xmx)不是一种选择吗?

于 2010-07-02T15:38:59.060 回答