我有一个列表输出看起来像这样的片段:如何变换成列表查找表
[[1]]
[1] 109
[[2]]
integer(0)
[[3]]
[1] 80
有没有办法把它改造成这种格式?
C1 C2
1 109
2 0 (or NA)
3 80
不知道在哪里甚至开始......如果我选择不公开它,我发现我失去了我的整数(0)的位置,这是非常重要,我保持。
类我有一个列表输出看起来像这样的片段:如何变换成列表查找表
[[1]]
[1] 109
[[2]]
integer(0)
[[3]]
[1] 80
有没有办法把它改造成这种格式?
C1 C2
1 109
2 0 (or NA)
3 80
不知道在哪里甚至开始......如果我选择不公开它,我发现我失去了我的整数(0)的位置,这是非常重要,我保持。
类随着as.numeric
可以保留integer(0)
为NA
。
data.frame(C1 = seq(length(lst)), C2 = as.numeric(lst))
# C1 C2
#1 1 109
#2 2 NA
#3 3 80
也'seq_along(lst)'。 – lmo
L = list(109,integer(0),80)
sapply(L, '[', 1:1) #OR sapply(L, function(a) a[1])
#[1] 109 NA 80
#If you need a data.frame
data.frame(cbind(1:length(L),lapply(L, '[', 1:1)))
# X1 X2
#1 1 109
#2 2 NA
#3 3 80
我们可以通过stack
stack(setNames(lapply(lst, `length<-`, 1), seq_along(lst)))[2:1]
http://stackoverflow.com/questions/17388096/convert-list-with-null-entres-to-data-frame-的可能重复做在-r – akrun