0

以下代码在同一列的不同行上创建一个带有字母 a 到 f 的 Excel 文件。有没有办法在仅使用一个 writeData() 函数的同时将字母分为 3 列和 2 行?

wb <- createWorkbook()
addWorksheet(wb, 1)
writeData(wb, 1, c("a", "b", "c", "d", "e", "f"), startCol = 5, startRow = 5)
saveWorkbook(wb, file = "test.xlsx", overwrite = TRUE)

所以我希望它像这样输出:

a b c
d e f
4

1 回答 1

2

您正在为该writeData函数提供一个向量。这就是为什么您将所有内容都放在 1 列中的原因。如果您提供矩阵或 data.frame,您将获得所需的结果。下面是一个简单的示例,可以满足您的需求。

library(openxlsx)

wb <- createWorkbook()
addWorksheet(wb, 1)

writeData(wb, 1, 
          matrix(c("a", "b", "c", "d", "e", "f"), nrow = 2), # <-- matrix / data.frame
          colNames = FALSE, # <-- set colNames to false
          startCol = 5, 
          startRow = 5)
saveWorkbook(wb, file = "test.xlsx", overwrite = TRUE)
于 2019-02-02T14:39:15.223 回答