创建一个包含可变数量列表的列表

时间:2019-01-05 13:54:39

标签: r list

我需要按照以下格式从数据帧的行创建一个列表:

df <- data.frame(y1 = c("a", "d"), y2 = c("b", "e"), y3 = c("c", "f"))
df$y1 <- as.character(df$y1)
df$y2 <- as.character(df$y2)
df$y3 <- as.character(df$y3)
x <- list(
  list(y1 = df$y1[1],
       y2 = df$y2[1],
       y3 = df$y3[1]),
  list(y1 = df$y1[2],
       y2 = df$y2[2],
       y3 = df$y3[2])
)

> x
[[1]]
[[1]]$`y1`
[1] "a"

[[1]]$y2
[1] "b"

[[1]]$y3
[1] "c"


[[2]]
[[2]]$`y1`
[1] "d"

[[2]]$y2
[1] "e"

[[2]]$y3
[1] "f"

当数据帧中有两行时,这是一个示例。当数据框中的行数可变时,如何实现?因此,对于数据框中的每一行,都应该有一个列表。

4 个答案:

答案 0 :(得分:2)

我们还可以使用apply,方法是遍历各行并将as.list应用于各行:

apply(df, 1, as.list)
[[1]]
[[1]]$y1
[1] "a"

[[1]]$y2
[1] "b"

[[1]]$y3
[1] "c"


[[2]]
[[2]]$y1
[1] "d"

[[2]]$y2
[1] "e"

[[2]]$y3
[1] "f"

答案 1 :(得分:1)

我们首先split数据帧的每一行,然后对于每一行,我们使用as.list将每个元素转换为单独的列表元素

lapply(split(df, 1:nrow(df)), as.list)


#$`1`
#$`1`$y1
#[1] "a"

#$`1`$y2
#[1] "b"

#$`1`$y3
#[1] "c"


#$`2`
#$`2`$y1
#[1] "d"

#$`2`$y2
#[1] "e"

#$`2`$y3
#[1] "f"

答案 2 :(得分:1)

我们可以使用transpose中的purrr

library(purrr)
transpose(df)
#[1]]
#[[1]]$y1
#[1] "a"

#[[1]]$y2
#[1] "b"

#[[1]]$y3
#[1] "c"


#[[2]]
#[[2]]$y1
#[1] "d"

#[[2]]$y2
#[1] "e"

#[[2]]$y3
#[1] "f"

答案 3 :(得分:0)

也许这可以帮助您:

lst1 <- sapply(df,list)
lst2 <- lapply(lst1, function(x) split(x, lst1$y2))