Revision fe07bfa906d7e155439160caee538a3449cd3877 authored by Dominique Makowski on 08 April 2019, 08:42:41 UTC, committed by cran-robot on 08 April 2019, 08:42:41 UTC
0 parent
utils_flatten_list.R
#' Flatten a list
#'
#' @param object A list.
#' @param name Name of column of keys in the case the output is a dataframe.
#' @keywords internal
flatten_list <- function(object, name = "name") {
if (length(object) == 1) {
object[[1]]
} else if (all(sapply(object, is.data.frame))) {
if (is.null(names(object))) {
as.data.frame(t(sapply(object, rbind)))
} else {
tryCatch({
rn <- names(object)
object <- do.call(rbind, object)
object[name] <- rn
object[c(name, setdiff(names(object), name))]
}, warning = function(w) {
object
}, error = function(e) {
object
})
}
} else {
object
}
}
Computing file changes ...