我正在导出一个非常大的碧玉报告(大约 20000 页)。为此,为了避免内存不足错误,正如不同网站所建议的那样,我正在使用 JRSwapFileVirtualize,如下所示:
virtualizer = new JRSwapFileVirtualizer(1000, new JRSwapFile(reportFilePath, 2048, 1024), true);
parameters.put(JRParameter.REPORT_VIRTUALIZER, virtualizer);
.
.
JasperPrint print = JasperFillManager.fillReport(report, parameters, list);
virtualizer.cleanup();
我的问题是:
1)我将maxSize配置为1000,20000页的报表可以吗?
2)我在方法调用“fillReport”后立即清理虚拟器。是否正确,或者我需要在将报告导出到 XLS 后清理虚拟器?
3)无论如何在导出报告后清理虚拟器,对我有帮助吗?
4) 创建 JasperPrint 对象,逻辑写在服务器端。导出报表逻辑,是用java客户端写的。如果我应该清理虚拟器,在导出报告后,我该如何处理这种情况?因为在这种情况下,我需要在服务器端创建此虚拟器的静态对象(因为 JRSwapFileVirtualizer 不可序列化,因此我无法在服务器和客户端之间创建并传递它),然后在导出后再次调用服务器端方法进行清理虚拟机。我在想创建静态对象是有风险的,因为如果对服务器端逻辑进行多次调用,那么虚拟器静态对象将保存对最新调用创建的交换文件的引用,因此在清理之后,以前的交换文件可能不会被删除.
我找到了有关此主题的更多信息:在 jasper 提供的使用虚拟器的示例中,他们仅在调用 common export 时清理虚拟器,它导出了多种类型的文件。当他们只导出单一类型的报告时,他们没有调用清理:
else if (TASK_CSV.equals(taskName))
{
exportCSV(jasperPrint);
}
else if (TASK_EXPORT.equals(taskName))
{
exportPDF(jasperPrint);
exportXML(jasperPrint, false);
exportHTML(jasperPrint);
exportCSV(jasperPrint);
// manually cleaning up
virtualizer.cleanup();
}
他们也没有在这个例子中提到 XLS 导出。我找到了另一个链接,该人遇到了同样的问题,但也没有提到解决方案:
http://www.jasperforge.org/plugins/espforum/view.php?group_id=102&forumid=103&topicid=95689
此链接还说我们可以改用 JRXlsxExporter 。但是 JRXlsxExporter 只导出 excel 2007 格式而不是 2003 格式。
我正在使用 JExcelApiExporter.exportReport() 将报告导出到 XLS,对于大型报告它不起作用。请帮我解决这个问题。任何小的提示或建议都是可以理解的。如果您需要更多信息,请告诉我。谢谢。