gpt4 book ai didi

R (purrr) 将命名列表的列表展平以列出并保留名称

转载 作者:行者123 更新时间:2023-12-01 13:22:47 27 4
gpt4 key购买 nike

也许我遗漏了一些明显的东西,但我试图将 R 中命名列表的命名列表(甚至可能更多嵌套)扁平化为最终一个扁平列表。 purrrrlist似乎有工具。我怎样才能实现子列表的名称成为扁平结果列表的名称预加密,例如list1.blist.apurrr ?我的实际列表更深入地嵌套了不同数量的级别和不同级别的重复名称。最后我表演purrr::map_df(final_list, bind_rows)这似乎删除了所有重复名称(即使没有,我也不知道原始重复名称来自哪个分支)。我可以用 rlist但我曾希望有一个 tidyverse解决方案(与出色的 rlist 无关,但许多已经安装了 tidyverse)。

编辑:

另请注意 rlist::list.flatten()将始终删除除顶部之外的所有级别,而 purrr::flatten()一次下降一个级别,这有时可能是您所需要的。您可以根据需要多次嵌套 purrr::map(.x, .f = rlist::list.flatten) 来实现相同的效果,但它很麻烦且不美观/可读。

alist <- list(list1 = list(a = 1, b = 2, blist = list(a = 3, b = 4)),
list2 = list(a = 1, b = 2, blist = list(a = 3, b = 4)))
str(alist)

List of 2
$ list1:List of 3
..$ a : num 1
..$ b : num 2
..$ blist:List of 2
.. ..$ a: num 3
.. ..$ b: num 4
$ list2:List of 3
..$ a : num 1
..$ b : num 2
..$ blist:List of 2
.. ..$ a: num 3
.. ..$ b: num 4

alist_flat <- purrr::map(alist, purrr::flatten)
str(alist_flat)

List of 2
$ list1:List of 4
..$ a: num 1
..$ b: num 2
..$ a: num 3
..$ b: num 4
$ list2:List of 4
..$ a: num 1
..$ b: num 2
..$ a: num 3
..$ b: num 4

alist_flattest <- purrr::flatten(alist_flat)
str(alist_flattest)

List of 8
$ a: num 1
$ b: num 2
$ a: num 3
$ b: num 4
$ a: num 1
$ b: num 2
$ a: num 3
$ b: num 4

# works with rlist
alist_flat_names <- map(alist, rlist::list.flatten, use.names = TRUE)
str(alist_flat_names)

List of 2
$ list1:List of 4
..$ a : num 1
..$ b : num 2
..$ blist.a: num 3
..$ blist.b: num 4
$ list2:List of 4
..$ a : num 1
..$ b : num 2
..$ blist.a: num 3
..$ blist.b: num 4

alist_flattest_names <- rlist::list.flatten(alist_flat_names, use.names = TRUE)
str(alist_flattest_names)

List of 8
$ list1.a : num 1
$ list1.b : num 2
$ list1.blist.a: num 3
$ list1.blist.b: num 4
$ list2.a : num 1
$ list2.b : num 2
$ list2.blist.a: num 3
$ list2.blist.b: num 4

最佳答案

我查看了 rlist::list.flatten() 的源代码并将源代码复制到一个新函数中以避免这种依赖性。

my_flatten <- function (x, use.names = TRUE, classes = "ANY") 
{
#' Source taken from rlist::list.flatten
len <- sum(rapply(x, function(x) 1L, classes = classes))
y <- vector("list", len)
i <- 0L
items <- rapply(x, function(x) {
i <<- i + 1L
y[[i]] <<- x
TRUE
}, classes = classes)
if (use.names && !is.null(nm <- names(items)))
names(y) <- nm
y
}

alist <- list(list1 = list(a = 1, b = 2, blist = list(a = 3, b = 4)),
list2 = list(a = 1, b = 2, blist = list(a = 3, b = 4)))


flat_list <- my_flatten(alist)

str(flat_list)

结果:
List of 8
$ list1.a : num 1
$ list1.b : num 2
$ list1.blist.a: num 3
$ list1.blist.b: num 4
$ list2.a : num 1
$ list2.b : num 2
$ list2.blist.a: num 3
$ list2.blist.b: num 4

关于R (purrr) 将命名列表的列表展平以列出并保留名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49252400/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com