将data.frame转换为列表列表

时间:2019-03-08 18:51:57

标签: r dataframe

我试图弄清楚如何将data.frame转换为列表列表。假设我有(如果以后需要捕获更多属性,可以随意修改):

v <- list(
          row1=list(col1 = as.Date("2011-01-23"), col2="A"), 
          row2=list(col1 = as.Date("2012-03-03"), col2="B"))
d <- do.call(rbind, lapply(v, as.data.frame))
d$col3 <- 2

如何将d返回到列表列表(类似于v)。最终结果应等于以下结果:

vr <- list(
          row1=list(col1 = as.Date("2011-01-23"), col2="A", col3=2), 
          row2=list(col1 = as.Date("2012-03-03"), col2="B", col3=2))

2 个答案:

答案 0 :(得分:5)

你可以

out <- lapply(split(d, rownames(d)), as.list)
out
#$row1
#$row1$col1
#[1] "2011-01-23"

#$row1$col2
#[1] "A"

#$row1$col3
#[1] 2


#$row2
#$row2$col1
#[1] "2012-03-03"

#$row2$col2
#[1] "B"

#$row2$col3
#[1] 2

如果在创建stringsAsFactors = FALSE时添加d,即

d <- do.call(rbind, lapply(v, as.data.frame, stringsAsFactors = FALSE))
d$col3 <- 2

然后

identical(out, vr)

返回TRUE

答案 1 :(得分:2)

在将它们作为主列表元素的值传递之前,您必须再次遍历这些列以使其成为列表。我希望下面的代码有帮助:

apply(d,MARGIN = 1, FUN=function(x){as.list(x)})