首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将数据列表保存到一个带有R的多张工作表的excel中

将数据列表保存到一个带有R的多张工作表的excel中
EN

Stack Overflow用户
提问于 2022-03-16 07:14:37
回答 1查看 213关注 0票数 0

给出了由以下代码生成的数据格式dfs列表:

代码语言:javascript
运行
复制
df <- structure(list(id = c("M0000607", "M0000609", "M0000612"), `2021-08(actual)` = c(12.6, 
19.2, 8.3), `2021-09(actual)` = c(10.3, 17.3, 6.4), `2021-10(actual)` = c(8.9, 
15.7, 5.3), `2021-11(actual)` = c(7.3, 14.8, 3.1), `2021-12(actual)` = c(6.1, 
14.2, 3.5), `2021-08(pred)` = c(11.65443222, 14.31674997, 7.084180415
), `2021-09(pred)` = c(12.29810914, 17.7143733, 6.057927385), 
    `2021-10(pred)` = c(9.619846116, 15.54553601, 6.525992602
    ), `2021-11(pred)` = c(8.352097939, 13.97318204, 3.164682627
    ), `2021-12(pred)` = c(6.113631596, 14.16243166, 3.288372517
    ), `2021-08(error)` = c(2.082307066, 1.146759554, 0.687406723
    ), `2021-09(error)` = c(1.631350383, 2.753457736, 2.952737781
    ), `2021-10(error)` = c(0.945567783, 4.883250027, 1.215819585
    ), `2021-11(error)` = c(1.998109138, 0.414373304, 0.342072615
    ), `2021-12(error)` = c(0.719846116, 0.154463985, 1.225992602
    )), class = "data.frame", row.names = c(NA, -3L))

year_months <- c('2021-12', '2021-11', '2021-10')  
curr <- lubridate::ym(year_months)
prev <- curr - months(2L)
dfs <- mapply(function(x, y) {
  df[c(
    "id", 
    format(seq.Date(y, x, by = "month"), "%Y-%m(actual)"), 
    format(x, "%Y-%m(pred)"), 
    format(x, "%Y-%m(error)")
  )]
}, curr, prev, SIMPLIFY = FALSE)
print(dfs)

输出:

代码语言:javascript
运行
复制
[[1]]
        id 2021-10(actual) 2021-11(actual) 2021-12(actual) 2021-12(pred) 2021-12(error)
1 M0000607             8.9             7.3             6.1      6.113632      0.7198461
2 M0000609            15.7            14.8            14.2     14.162432      0.1544640
3 M0000612             5.3             3.1             3.5      3.288373      1.2259926

[[2]]
        id 2021-09(actual) 2021-10(actual) 2021-11(actual) 2021-11(pred) 2021-11(error)
1 M0000607            10.3             8.9             7.3      8.352098      1.9981091
2 M0000609            17.3            15.7            14.8     13.973182      0.4143733
3 M0000612             6.4             5.3             3.1      3.164683      0.3420726

[[3]]
        id 2021-08(actual) 2021-09(actual) 2021-10(actual) 2021-10(pred) 2021-10(error)
1 M0000607            12.6            10.3             8.9      9.619846      0.9455678
2 M0000609            19.2            17.3            15.7     15.545536      4.8832500
3 M0000612             8.3             6.4             5.3      6.525993      1.2158196

如果dfs有大量的元素,我如何使用apply家族函数或purrr::map将它们保存到一个包含多个工作表的excel中?

PS:该表将由%Y-%m根据上一列的名称命名。

若要保存没有应用功能的多个数据文件,请执行以下操作:

代码语言:javascript
运行
复制
library(openxlsx)
# define sheet names for each data frame
dataset_names <- list('Sheet1' = dfs[1], 'Sheet2' = dfs[2], 'Sheet3' = dfs[3])
# export each data frame to separate sheets in same Excel file
openxlsx::write.xlsx(dataset_names, file = 'mydata.xlsx') 

若要获取上列的名称,请执行以下操作:

代码语言:javascript
运行
复制
rev(colnames(dfs[[1]]))[1]

退出:

代码语言:javascript
运行
复制
"2021-12(error)"

对于这个示例数据,我将有一个带有工作表名的excel文件mydata.xlsx2021-10, 2021-11, 2021-12

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-16 07:34:33

你可以:

代码语言:javascript
运行
复制
library(tidyverse)
names(dfs) <- lapply(dfs, function(x) x |> select(last_col()) |> names())

openxlsx::write.xlsx(dfs, file = 'mydata.xlsx') 

更新:如果您想拥有通用的"Sheet X“名称,您可以这样做:

代码语言:javascript
运行
复制
names(dfs) <- paste0("Sheet", 1:length(dfs))

更新2:删除“(错误)”部分:

代码语言:javascript
运行
复制
names(dfs) <- str_remove(lapply(dfs, function(x) x |> select(last_col()) |> names()), "\\(error\\)")
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71493037

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档