小编Luk*_*kas的帖子

如何直接从列表中的所有嵌套列表中选择相同的列?

是否可以直接选择列表中所有嵌套列表的列?
我的列表是使用aggregate()和table()创建的:

AgN=aggregate(data,by=list(d$date),FUN=table,useNA="no")
Run Code Online (Sandbox Code Playgroud)

AgN$x 好像:

$`0`

      1           2           3           9          11 
0.447204969 0.438509317 0.096894410 0.009937888 0.007453416 

$`1`

          1           2           4           8          11 
0.489974937 0.389724311 0.102756892 0.006265664 0.011278195 

…

$n
Run Code Online (Sandbox Code Playgroud)

我想获得每个表的特定列的向量,例如包含名为"1"的所有列的值的向量.我仍然是R初学者,但即使经过长时间的搜索和尝试,我找不到好的解决方案.如果我想获得列表的字段,我可以简单地用括号对其进行索引,例如[i,j].
在线我发现了一些矩阵的例子,所以我尝试做同样的事情,首先只选择一个嵌套列表的列AgN$x[1][1],但是仍然选择一个完整的列表:

$0

     1           2           3           8          11 
Run Code Online (Sandbox Code Playgroud)

0.447204969 0.438509317 0.096894410 0.009937888 0.007453416

我的下一次尝试是AgN$x[[1]][1],它正在工作:

  1 
Run Code Online (Sandbox Code Playgroud)

0.447205

所以我试图选择所有嵌套列表的每个第一列的值:

AgN$x[[1:length(AgN$x]][1]
Recursive indexing failed at level 2
Run Code Online (Sandbox Code Playgroud)

显然问题是如果使用双括号则禁止选择范围.

我的最后一次尝试是使用for循环:

cduR=NULL 
for (i in 1:length(AgN$x)){
t=AgN$x[[i]]
cduR=c(cduR,as.vector(t["1"]))
}
Run Code Online (Sandbox Code Playgroud)

最后,到目前为止似乎有效.但是这样我每次想要选择列时都必须构建一个循环.有没有直接的方法?

谢谢你的帮助.

r nested-lists

28
推荐指数
1
解决办法
3万
查看次数

标签 统计

nested-lists ×1

r ×1