- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的应用程序创建了一个电子表格,这可能相当大(最多 500,000 行,每行分布在六张纸上,每张纸大约有 20 列)。
我使用 Apache Poi 并转而使用 SXSSFWorkBook 将数据写入临时文件,这样使用的内存与最终电子表格的大小不成比例,而且效果很好。
但电子表格表示元数据已更改,当元数据已更改时,我想向显示旧值的单元格添加注释。我在小型电子表格上工作,但在尝试大型文件时它总是因堆内存错误而失败。
我不确定问题是由于 Poi 将所有评论存储在内存中的限制还是我做错了。 Worksheet 是我自己的包装类,我只为每个工作表创建一个 DrawingPatriach 类,但看起来我必须为我需要的每个评论创建一个 anchor 。
private void addCellComment(Row r, Cell c, Worksheet sheet, String value)
{
String formattedValue = value.replace('\u0000', '\n');
int rowCount = value.split("\\\\u000").length;
ClientAnchor anchor = factory.createClientAnchor();
anchor.setCol1(c.getColumnIndex());
anchor.setCol2(c.getColumnIndex()+2);
anchor.setRow1(r.getRowNum());
anchor.setRow2(r.getRowNum()+rowCount);
Drawing drawing = sheet.getDrawing();
Comment comment = drawing.createCellComment(anchor);
RichTextString str = factory.createRichTextString(formattedValue);
comment.setString(str);
c.setCellComment(comment);
}
最佳答案
嗯,来自Apache POI documentation (强调我的):
Please note that there are still things that still may consume a large amount of memory based on which features you are using, e.g. merged regions, hyperlinks, comments, ... are still only stored in memory and thus may require a lot of memory if used extensively.
所以我猜这是 Apache POI 的限制,您必须解决这个问题。
关于java - 使用 Poi SXSSFWorkbook 向 Excel 添加注释时使用的内存过多,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42922120/
下面是创建 SXSSFWorkbook 的示例代码片段: try(SXSSFWorkbook wb = new SXSSFWorkbook()) { //... } finally {
我曾经使用过XSSFWorkbook,它在所有设备上都能正常工作(即使对于MAC),但现在我迁移到SXSSFWorkbook,所以现在我面临一个问题xlsx文件不可以在MAC上查看 In detail
有没有办法获取SXSSFWorkbook生成的Excel的大小。 我需要检查生成的文件的大小,并根据大小执行不同的操作,例如,如果大小较小,则直接发送电子邮件;如果大小超过一定限制,则上传到某个位置。
是否可以在流式 SXSSFWorkbook 上使用 autoSizeColumns?我实现了导出功能以将对象列表导出到 excel。起初我使用 XSSFWorkbook(不是流式处理),在创建所有单元
在我的项目中更大的代码流中,我试图创建一个空白的 SXSSFWorkbook 并创建工作表并向其写入数据,但我无法这样做,因为它给了我一个运行时异常:没有这样的文件或目录。我不明白为什么会发生这种情况
我正在自动化从 HDFS 读取文件到达时间,并在所有系统的 Excel 工作表中填充数据,并在超过阈值时间时对计时进行着色。我已经使用 shell 脚本和 java 进行 Excel 处理来完成这些工
我正在尝试使用 SXSSFWorkbook 从头开始编写 Excel 电子表格。 wb = SXSSFWorkbook(500) wb.isCompressTempFile
我需要将行追加到工作簿的工作表中。我正在使用 org.apache.poi.xssf.streaming.SXSSFWorkbook 但我无法实现低内存占用。代码如下: import java.io.
我有一个用作模板的现有工作簿。我试图更新现有行中的单元格值,这意味着相邻的单元格有一个值。问题是在创建文件并打开它之后,出现以下错误:“Excel 在...中发现不可读的内容。” 我假设原因是 SXS
我正在使用 Apache POI SXSSFWorkbook 生成 .xlsx Excel 电子表格,但我需要将该文件保存到 blob 中,而不是下载它。我还需要它能够扩展,因此如果我将 600,00
我正在使用 apache 的 POI API 来编写 XLSX 文件。由于我需要写入大文件,因此我使用 Streaming API (SXSSF)。为此,我关注 this指导。请注意,在示例的末尾有一
我必须创建一个包含两张表的 Excel 工作簿。我使用以下代码创建 Excel,然后将其下载。但是,已创建第一个工作表,但未创建第二个工作表。我无法理解确切的原因。以下是我创建两张表的部分。 impo
我们正在构建一个 Spring boot REST 端点,它会生成一个大型 XLS 文件(可能包含约 100 万行)并提供下载。当前解决方案使用 Apache POI 库的 SXSSF API 来创建
我正在尝试使用 POI 进行第一个读取大型 xlsx 文件的测试,但是要对一个小文件进行简单测试,我无法显示单元格的值。 有人可以告诉我我的错误是什么。欢迎所有的建议。谢谢。 测试.java: imp
我的应用程序创建了一个电子表格,这可能相当大(最多 500,000 行,每行分布在六张纸上,每张纸大约有 20 列)。 我使用 Apache Poi 并转而使用 SXSSFWorkBook 将数据写入
情况是这样的:我正在获取 SXSSFWorkbook 对象,并且我需要使用该对象创建数据透视表。我们有什么办法可以实现它吗? 我已经检查了以下链接: Apache POI - is there a w
HSSFWorkbook 与 XSSFWorkbook 以及 XSSFWorkbook 和 SXSSFWorkbook 的优点/缺点? 最佳答案 每个 API 功能的电子表格: 来源:https://
我是 Java 开发人员。我正在尝试写一个大的xlsx文件 (Excel) 使用 SXSSFWorkbook Apache POI 库的类。 我没有选择写大文件,因为有超过 200000 行。 但我需
我们使用 Spring Batch 和 Apache POI 开发了一个应用程序,用于从 DB(Oracle) 读取数据并将其写入 apache-poi 生成的 XLSX 文件中。 示例下方有一个读取
有几个相关问题,但我找不到反射(reflect)我情况的问题。 我正在使用 SXSSFWorkbook 和 SXSSFSheet 对象通过 Apache POI 编写 Excel“xlsx”文件。该文
我是一名优秀的程序员,十分优秀!