4

打印图像并将其保存在磁盘上很简单:

fit <- lm(some ~ model)

png(filename="your/file/location/name.png")
plot(fit)
dev.off()

将一些数据写入excel电子表格

write.csv(rnorm(10),"some file",sep=",")

我的问题是如何将上述内容重定向到电子表格中。换句话说,将与一些图像/绘图配对的图形输出到 Excel 工作簿?

谢谢,

4

3 回答 3

10

我会使用这个xlsx包。检查addPicture功能和addDataFrame功能。我发现这个包很容易使用。

于 2013-07-31T17:06:56.993 回答
7

insertImage您可以对函数和使用openxlsx包执行相同的操作。

我从上面复制了这个例子,但是使用了 openxlsx 包:

# Setup
x <- c('tidyverse', 'openxlsx')
sapply(X=x, FUN = require, character.only = TRUE)

# Create graph---------
dcs <- ggplot(mtcars) +
  geom_point(aes(cyl, disp))

# Export Pic -----------
pic_path <- "C:/home/dcs.jpeg"
png(filename = pic_path)
plot(dcs)
dev.off()

# Add to a new work book -------------
wb <- openxlsx::createWorkbook()
addWorksheet(wb, "Plots")
insertImage(wb, "Plots", pic_path)
openxlsx::saveWorkbook(wb,
                       "~/example.xlsx")

# Kill pic
unlink(pic_path)
于 2018-10-17T17:42:03.927 回答
5

只是添加一个关于 xlsx 包的示例,据我所知,它要求您首先保存图片,然后将其导入 xlsx 文件,请参阅下面的导出到现有书籍的可重现示例:

# Setup
x <- c('tidyverse', 'rJava', 'xlsxjars', 'xlsx')
sapply(X=x, FUN = require, character.only = TRUE)

# Create graph---------
dcs <- ggplot(mtcars) +
  geom_point(aes(cyl, disp))

# Export Pic -----------
pic_path <- "C:/home/dcs.jpeg"
png(filename = pic_path)
plot(dcs)
dev.off()

# Add to existing book -------------
xl_path <- "C:/home/a.xlsx"

wb <- loadWorkbook(xl_path)

ws <- getSheets(wb)["Summary"][[1]]

addPicture(file = pic_path, sheet = ws)

saveWorkbook(wb, xl_path)

# Kill pic
unlink(pic_path)

#Then write some data
write.xlsx(as.data.frame(output), xl_path, sheetName = 'data'))
于 2017-10-13T10:48:14.393 回答