编辑Excel工作表的特定单元格

时间:2014-11-14 18:29:17

标签: r excel xlconnect

我有一个Excel工作簿,我想使用R编辑/填充某些特定单元格,而不更改任何格式。

到目前为止,我已经尝试了 XLConnect 包,看起来它可以做我想要的事情,我只是找不到办法。< / p>

直接解决问题的方法:

wb <- loadWorkbook("file1.xls")
data1 <- readWorksheet(wb, "Sheet1", header=TRUE)

## adding a value to a particular cell:
data1[11,12] <- 3.2 

## rewriting old data:
writeWorksheet(wb, data1, "Sheet1")
saveWorkbook(wb, "new_file1.xls")

然而,这种方式新工作簿丢失了所有以前的格式(合并的单元格,公式等)。

有没有办法在不丢失剩余工作表的任何格式的情况下更改某些单元格中的值?

3 个答案:

答案 0 :(得分:4)

以下是使用R自动化Excel的示例。

library(RDCOMClient)
xlApp <- COMCreate("Excel.Application")
wb    <- xlApp[["Workbooks"]]$Open("file.1.xls")
sheet <- wb$Worksheets("Sheet1")

# change the value of a single cell
cell  <- sheet$Cells(11,12)
cell[["Value"]] <- 3.1

# change the value of a range
range <- sheet$Range("A1:F1")
range[["Value"]] <- paste("Col",1:6,sep="-")

wb$Save()                  # save the workbook
wb$SaveAS("new.file.xls")  # save as a new workbook
xlApp$Quit()               # close Excel

答案 1 :(得分:2)

使用XLC$STYLE_ACTION.NONE样式操作应该添加您的数据而不更改任何格式:

data1 <- readWorksheetFromFile("file1.xls", "Sheet1")

## adding a value to a particular cell:
data1[11,12] <- 3.2 

## rewriting old data:
writeWorksheetToFile("file1.xls", data1, "Sheet1", styleAction = XLC$STYLE_ACTION.NONE)

感谢Martin建议在评论中对此进行研究。

答案 2 :(得分:1)

如果您不需要使用公式,则有两种可能的解决方案。

您可以使用{xlsx}软件包:

library(xlsx)
xlsx::write.xlsx(x = head(iris),file = "source3.xlsx",sheetName = "A")
hop3 <- xlsx::loadWorkbook(file = "source3.xlsx")
sheets <- getSheets(hop3)
rows  <- getRows(sheets$A,rowIndex = 2)   # get all the rows
cc <- getCells(rows,colIndex = 3) 
xlsx::setCellValue(cc[[1]],value = "54321")
hop3$setForceFormulaRecalculation(TRUE)
xlsx::saveWorkbook(hop3,file = "output3.xlsx")

您还可以使用{XLconnect}

library(XLConnect)    
XLConnect::writeWorksheetToFile(file = "source2.xlsx",data = head(iris),sheet="A")
hop2 <- XLConnect::loadWorkbook(file = "source2.xlsx")
createName(hop2, name = "plop", formula = "A!C2")
writeNamedRegion(hop2, 12345, name = "plop", header = FALSE)

致谢