使用XLConnect将数据写入Excel模板会产生空单元格错误

时间:2015-01-06 22:02:57

标签: r excel xlconnect

我正在使用R包XLConnect将数据帧写入现有工作簿中的现有excel工作表。 excel工作簿有一个原始数据的工作表,我在R中使用writeWorksheet()填充,另一个工作表用于引用原始数据工作表并执行计算的格式化数据。但是,当我将数据写入R中的原始数据工作表时,格式化的数据工作表不会更新,并且会出现错误,即#34;公式引用空单元格",即使这些单元格中包含数据。我不确定这个错误是由于R和XLConnect还是我工作簿中的某些内容造成的。当我只是将我的数据直接复制并粘贴到我的原始数据导入工作表中的单元格中时,我没有收到错误。请参阅下面的示例,并感谢您的帮助:

在R:

library(XLConnect)

# Creating first data frame
L3 <- LETTERS[1:3]
fac <- sample(L3, 10, replace = TRUE)
(d <- data.frame(x = 1, y = 1:10, fac = fac))
df.1<-data.frame(1, 1:10, sample(L3, 10, replace = TRUE))

# Creating second data frame
L4 <- LETTERS[4:7]
fac <- sample(L4, 10, replace = TRUE)
(d <- data.frame(x = 1, y = 1:10, fac = fac))
df.2<-data.frame(1, 1:10, sample(L4, 10, replace = TRUE))

# Reading in workbook
wb      <- loadWorkbook(xlname)
wbnames <- as.vector(getSheets(wb)) # where wbnames is of length two
[1] "Raw Data Import"  [2] "Formatted Data"

# Writing df.1 and df.2 to specific locations in Raw Data Import worksheet
writeWorksheet(wb,df.1,sheet=wbnames[1],startRow=3,header=F)
writeWorksheet(wb,df.2,sheet=wbnames[1],startRow=15,header=F)

# Saving workbook
saveWorkbook(wb)

2 个答案:

答案 0 :(得分:3)

您可以使用XLConnect函数setForceFormulaRecalculation()。这会强制Excel在打开工作表时重新计算公式值。第二个参数允许您指定要重新计算的工作表。如果它设置为“*”,它将重新计算工作簿中的所有公式。

wb      <- loadWorkbook(xlname)
wbnames <- as.vector(getSheets(wb))
writeWorksheet(wb,df.1,sheet=wbnames[1],startRow=3,header=F)
writeWorksheet(wb,df.2,sheet=wbnames[1],startRow=15,header=F)
setForceFormulaRecalculation(wb,"*",TRUE)
saveWorkbook(wb,'~/test.xls')

答案 1 :(得分:0)

在我为每张工作表添加createSheet操作之前,我没有成功。如果您想使用现有的工作表信息,请查看getSheets?getSheetPos

> wb      <- loadWorkbook('~/test.xls')
> wbnames <- as.vector(getSheets(wb)) 
> createSheet(wb, "test1"); createSheet(wb, 'test2')
> writeWorksheet(wb,df.1,sheet='test1',startRow=3,header=F)
> writeWorksheet(wb,df.2,sheet='test2',startRow=15,header=F)
> saveWorkbook(wb,'~/test.xls')

当我稍后运行您的代码时,我发现两个数据帧都已写入Sheet1。如果我插入了saveWorkbook操作,我将数据放在不同的表格上:

> writeWorksheet(wb,df.1,sheet='Sheet1',startRow=3,header=F); saveWorkbook(wb,'~/test.xls')
> writeWorksheet(wb,df.2,sheet='Sheet2',startRow=15,header=F)
> saveWorkbook(wb,'~/test.xls')

XLConnect是一种准商业产品,我不认为他们会向SO提出问题,因此您可能需要联系Mirai Solutions,GMBH。