- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
xlsx
包可用于从 R 读取和写入 Excel 电子表格。不幸的是,即使对于中等大小的电子表格,也可能会发生 java.lang.OutOfMemoryError
。特别是,
Error in .jcall("RJavaTools", "Ljava/lang/Object;", "invokeMethod", cl, :
java.lang.OutOfMemoryError: Java heap spaceError in .jcall("RJavaTools", "Ljava/lang/Object;", "newInstance", .jfindClass(class), :
java.lang.OutOfMemoryError: GC overhead limit exceeded
(其他相关异常也是可能的,但较少见。)
在阅读电子表格时,有人就此错误提出了类似的问题。
Importing a big xlsx file into R?
与 CSV 相比,使用 Excel 电子表格作为数据存储介质的主要优点是您可以在同一个文件中存储多个工作表,因此这里我们考虑将数据框列表写入每个工作表一个数据框。此示例数据集包含 40 个数据框,每个数据框有两列,最多 200k 行。它被设计得足够大,可能会出现问题,但您可以通过更改 n_sheets
和 n_rows
来更改大小。
library(xlsx)
set.seed(19790801)
n_sheets <- 40
the_data <- replicate(
n_sheets,
{
n_rows <- sample(2e5, 1)
data.frame(
x = runif(n_rows),
y = sample(letters, n_rows, replace = TRUE)
)
},
simplify = FALSE
)
names(the_data) <- paste("Sheet", seq_len(n_sheets))
将其写入文件的自然方法是使用 createWorkbook
创建工作簿,然后循环调用 createSheet
的每个数据帧和 addDataFrame
。最后可以使用 saveWorkbook
将工作簿写入文件。我已将消息添加到循环中,以便更容易地查看它在哪里失败。
wb <- createWorkbook()
for(i in seq_along(the_data))
{
message("Creating sheet", i)
sheet <- createSheet(wb, sheetName = names(the_data)[i])
message("Adding data frame", i)
addDataFrame(the_data[[i]], sheet)
}
saveWorkbook(wb, "test.xlsx")
在具有 8GB RAM 的计算机上以 64 位运行此程序,首次运行 addDataFrame
时会抛出 超出 GC 开销限制
错误。
如何使用 xlsx
将大型数据集写入 Excel 电子表格?
最佳答案
这是一个已知问题: http://code.google.com/p/rexcel/issues/detail?id=33
虽然尚未解决,但问题页面 links to a solution通过 Gabor Grothendieck建议在加载 rJava
包之前通过设置 java.parameters
选项来增加堆大小。 (rJava
是 xlsx
的依赖项。)
options(java.parameters = "-Xmx1000m")
值1000
是Java堆允许使用的RAM的兆字节数;它可以替换为您喜欢的任何值。我的实验表明,值越大越好,您可以愉快地使用完整的 RAM 权利。例如,我使用以下方法获得了最佳结果:
options(java.parameters = "-Xmx8000m")
在具有 8GB RAM 的计算机上。
通过在循环的每次迭代中请求垃圾收集可以获得进一步的改进。正如 @gjabel 所指出的,R 垃圾收集可以使用 gc()
执行。 。我们可以定义一个Java垃圾回收函数,调用Java System.gc()
方法:
jgc <- function()
{
.jcall("java/lang/System", method = "gc")
}
然后循环可以更新为:
for(i in seq_along(the_data))
{
gc()
jgc()
message("Creating sheet", i)
sheet <- createSheet(wb, sheetName = names(the_data)[i])
message("Adding data frame", i)
addDataFrame(the_data[[i]], sheet)
}
通过这两个代码修复,代码在抛出错误之前一直运行到 i = 29
。
我尝试过的一种不成功的技术是使用write.xlsx2
在每次迭代时将内容写入文件。这比其他代码慢,并且在第 10 次迭代时失败(但至少部分内容被写入文件)。
for(i in seq_along(the_data))
{
message("Writing sheet", i)
write.xlsx2(
the_data[[i]],
"test.xlsx",
sheetName = names(the_data)[i],
append = i > 1
)
}
关于r - 从 R 写入 Excel 时处理 java.lang.OutOfMemoryError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21937640/
在 Tomcat 6/Ubuntu 12.04 上启动 Grails 2.1.0 应用程序时出现以下错误。 Error 500 - Internal Server Error. groovy.lang
在运行 Storm 拓扑时,我收到此错误。拓扑完美运行 5 分钟,没有任何错误,然后失败。我正在使用 Config.TOPOLOGY_TICK_TUPLE_FREQ_SECS as 300 sec i
我有一个 jsp 代码在其中一台机器上运行良好。但是当我复制到另一台机器时,我得到了这个 no such method found 异常。我是 Spring 的新手。有人可以解释我错过了什么吗? 以下
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我的代码在下面给出了一个错误; Exception in thread "main" java.lang.NoSuchMethodError: com/myApp/Client.cypherCBC(L
我正在尝试一个 Restful web 服务示例,所以当我要访问 url 时,我遇到了异常 java.lang.NoSuchMethodError: jersey.repackaged.com.goo
我正在将一个 Spring web 项目转换为一个 Maven 项目,但我收到了这个错误: java.lang.NoSuchMethodError: org.jboss.logging.Logger.
在我的项目中,我有一个像这样的枚举: public enum MyEnum { FIRST(1), SECOND(2); private int value; private MyEnum(int v
我创建了这个简单的示例,用于读取 Linux 正常运行时间: public String getMachineUptime() throws IOException { String[] di
我正在使用 Eclipse,并且正在使用 Java。我的目标是使用 bogoSort 方法对 vector 进行排序在一个 vector (vectorExample)中适应我的 vector 类型,
我正在运行以下查询。它显示一条错误消息。如何解决这个错误? ListrouteList=null; List companyList = session.createS
我有以下模型类: @Entity @Table(name="user_content") @org.hibernate.annotations.NamedQueries({ @org.
我有那个错误。这是我的代码: GmailSettingsService service = new GmailSettingsService(APPLICATION_NAME, DOMAIN_NAME
实际上我在执行我的java程序时遇到了下面提到的错误 Exception in thread "pool-1-thread-1" java.lang.ClassCastException: jav
java.lang.ClassCastException: java.lang.Float cannot be cast to java.lang.String 我在以下代码中遇到此异常: Strin
我正在尝试从 linkedhashset 中检索随机元素。下面是我的代码,但它每次都给我异常。 private static void generateRandomUserId(Set userIds
我已经完成了 Android 中的代码: List spinnerArray = new ArrayList(); for (int i = 0; i item = (LinkedTreeMap)
这个问题已经有答案了: Explanation of ClassCastException in Java (12 个回答) 已关闭 6 年前。 我已经编写了 java 到 Json 的代码,同时从页
这个问题在这里已经有了答案: ClassCastException java.lang.Long cannot be cast to clojure.lang.IFn (4 个答案) 关闭 6 年前
我在运行时遇到问题来编译这段代码,这给我一个错误,java.lang.Integer 无法转换为 Java.lang.Double。如果有人帮助我更正此代码,我将非常高兴 double x; pu
我是一名优秀的程序员,十分优秀!