gpt4 book ai didi

r - 将 data.frame 转换为列表列表

转载 作者:行者123 更新时间:2023-12-02 07:18:10 27 4
gpt4 key购买 nike

我想弄清楚如何将 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

关于r - 将 data.frame 转换为列表列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55069310/

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