[英]Convert data.frame to list of lists
我试图弄清楚如何将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))
你可以做
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
如果在创建d
时添加stringsAsFactors = FALSE
,即
d <- do.call(rbind, lapply(v, as.data.frame, stringsAsFactors = FALSE))
d$col3 <- 2
然后
identical(out, vr)
返回TRUE
。
在将它们作为主列表元素的值传递之前,必须再次遍历列,使它们成为列表。 我希望以下代码有助于:
apply(d,MARGIN = 1, FUN=function(x){as.list(x)})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.