繁体   English   中英

从R中具有重复子元素的列表中删除元素

[英]Removing elements from a list in R with duplicated subelements

我在R中有一个列表,里面有几个属性,例如:

[[1]]
[[1]]$membership
[1] 1 1 1 2 2 2 1 3 3
[[2]]$csize
[1] 4 3 2
[[3]]$no
[1] 3

[[2]]
[[1]]$membership
[1] 1 1 2 2 2 3 1 3 3 4 4
[[2]]$csize
[1] 3 3 3 2
[[3]]$no
[1] 4

[[3]]
[[1]]$membership
[1] 1 2 2 2 2 3 1 3 4 4 4
[[2]]$csize
[1] 2 4 2 3
[[3]]$no
[1] 4

等等。

但是,列表中的某些元素具有相同的$no 例如,对于元素[[1]] ,我有[[1]][[3]]$no [1]3 ; 对于元素[[2]] ,我有[[2]][[3]]$no [1] 4 对于元素[[3]] ,我有[[3]][[3]]$no [1] 4 对于元素[[4]] ,我有[[4]][[3]]$no [1] 5

如何将列表的所有元素都保留为$no 谢谢!

也许像下面这样会做到的。
首先,创建一个与您的结构相同的列表。

lst <- lapply(1:3, function(x) list(membership = 1 + x, csize = 2 + x, no = 12 + (x > 1)))

现在看到的元素有重复no载体和其子集。

inx <- !duplicated(sapply(lst, function(x) x$no))
lst[inx]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM