From 05ddff88cbff2e76d0a4182c0c412ade65385d64 Mon Sep 17 00:00:00 2001 From: Maike Date: Thu, 15 Aug 2024 20:44:10 +0200 Subject: [PATCH] Add example to map_dfr()/map_dfc() Example to demonstrate an edge case, where map_dfr() works, but can not be replaced by list_rbind(). Fixes #1074 --- R/superseded-map-df.R | 31 +++++++++++++++++++++++++++++++ man/map_dfr.Rd | 27 +++++++++++++++++++++++++++ 2 files changed, 58 insertions(+) diff --git a/R/superseded-map-df.R b/R/superseded-map-df.R index 065aa9c9..a0df6a72 100644 --- a/R/superseded-map-df.R +++ b/R/superseded-map-df.R @@ -41,6 +41,32 @@ #' map(\(mod) as.data.frame(t(as.matrix(coef(mod))))) |> #' list_rbind() #' +#' # map: combining vectors --------------------------- +#' DF <- structure( +#' list( +#' `Column A` = c(" 13", " 15 "), +#' `Column B` = c(" 34", " 67 ") +#' ), +#' class = c("data.frame"), +#' row.names = c(NA, -2L) +#' ) +#' +#' # Was: +#' # map_dfr() and map_dfc() actually both combine the list by column +#' map_dfr(DF, trimws) +#' map_dfc(DF, trimws) +#' +#' # Now: +#' # to combine a list of vectors use as_tibble() +#' map(DF, trimws) |> tibble::as_tibble() +#' +#' # list_rbind()/list_cbind() require list of data.frames or NULL to work and +#' # will throw an error +#' \dontrun{ +#' map(DF, trimws) |> list_rbind() +#' map(DF, trimws) |> list_cbind() +#' } +#' #' # map2 --------------------------------------------- #' #' ex_fun <- function(arg1, arg2){ @@ -59,6 +85,11 @@ #' map2_dfc(arg1, arg2, ex_fun) #' # now #' map2(arg1, arg2, ex_fun) |> list_cbind() +#' + + + + map_dfr <- function(.x, .f, ..., .id = NULL) { # in 1.0.0 lifecycle::signal_stage("superseded", "map_dfr()", I("`map()` + `list_rbind()`")) diff --git a/man/map_dfr.Rd b/man/map_dfr.Rd index 3274f223..d4f17e3d 100644 --- a/man/map_dfr.Rd +++ b/man/map_dfr.Rd @@ -71,6 +71,32 @@ mtcars |> map(\(mod) as.data.frame(t(as.matrix(coef(mod))))) |> list_rbind() +# map: combining vectors --------------------------- +DF <- structure( +list( + `Column A` = c(" 13", " 15 "), + `Column B` = c(" 34", " 67 ") +), +class = c("data.frame"), +row.names = c(NA, -2L) +) + +# Was: +# map_dfr() and map_dfc() actually both combine the list by column +map_dfr(DF, trimws) +map_dfc(DF, trimws) + +# Now: +# to combine a list of vectors use as_tibble() +map(DF, trimws) |> tibble::as_tibble() + +# list_rbind()/list_cbind() require list of data.frames or NULL to work and +# will throw an error +\dontrun{ + map(DF, trimws) |> list_rbind() + map(DF, trimws) |> list_cbind() +} + # map2 --------------------------------------------- ex_fun <- function(arg1, arg2){ @@ -89,5 +115,6 @@ map2(arg1, arg2, ex_fun) |> list_rbind() map2_dfc(arg1, arg2, ex_fun) # now map2(arg1, arg2, ex_fun) |> list_cbind() + } \keyword{internal}