我有一个列表,想从中删除单个元素。如何做到这一点?
我试图在参考手册中查找我认为显而易见的函数名称,但没有找到合适的内容。
我有一个列表,想从中删除单个元素。如何做到这一点?
我试图在参考手册中查找我认为显而易见的函数名称,但没有找到合适的内容。
x <- list("a", "b", "c", "d", "e") # example list
x[-2] # without 2nd element
x[-c(2, 3)] # without 2nd and 3rd
x[x != "b"] # without elements that are "b"
df <- data.frame(number = 1:5, name = letters[1:5])
df[df$name != "b", ] # rows without "b"
df[df$number %% 2 == 1, ] # rows with odd numbers only
x$b
,也不能从列表元素x[[2]] = c("b","k")
中删除“b”。 - Carl Witthoft%in%
来测试多个项目。我不确定您所说的“无法删除x $ b”的意思 - 您是指删除整个列b
吗? - Florian JennError in list[length(list)] <- NULL : replacement has length zero
。 - wfbarksdalewithin
的 @Kim 的答案似乎是删除列表元素的“正确”方法,因为它允许使用字符字符串来标识列表元素,可以同时删除多个元素,并且不需要在原地进行。除了 OP 的问题是关于删除单个元素之外,我还错过了什么吗?谢谢。 - Josh我想补充说明,如果这是一个命名列表,你可以直接使用within
。
l <- list(a = 1, b = 2)
> within(l, rm(a))
$b
[1] 2
因此,您可以覆盖原始列表。
l <- within(l, rm(a))
从列表l
中删除名为a
的元素。within(l, rm(a, b))
。 - Vladx <- c("a","b"); within(l,rm(list=x))
- José以下是如何从 R 中删除一个列表的最后一个元素:
x <- list("a", "b", "c", "d", "e")
x[length(x)] <- NULL
如果x可能是一个向量,那么你需要创建一个新的对象:
x <- c("a", "b", "c", "d", "e")
x <- x[-length(x)]
一行代码删除列表中的Null元素:
x = x[-(which(sapply(x, is.null), arr.ind=TRUE))]
干杯!
x
是一个空列表时,这段代码会出错。建议改用 plyr
包中的 compact
函数来完成这个任务。 - Richie Cotton-(which(sapply(x,is.null),arr.ind=TRUE))
返回 named integer(0)
,这将完全删除该行。 - user3055034如果您有一个命名列表并想要删除特定元素,则可以尝试以下方法:
lst <- list(a = 1:4, b = 4:8, c = 8:10)
if("b" %in% names(lst)) lst <- lst[ - which(names(lst) == "b")]
这将创建一个名为lst
的列表,其中包含a
,b
和c
元素。第二行在检查b
存在的情况下删除它(以避免@hjv提到的问题)。
或者更好:
lst$b <- NULL
这样尝试删除不存在的元素就不是问题了 (例如,lst$g <- NULL
)。
使用-
(负号)以及元素的位置,例如如果要删除第3个元素,请将其用作your_list[-3]
输入
my_list <- list(a = 3, b = 3, c = 4, d = "Hello", e = NA)
my_list
# $`a`
# [1] 3
# $b
# [1] 3
# $c
# [1] 4
# $d
# [1] "Hello"
# $e
# [1] NA
从列表中删除单个元素
my_list[-3]
# $`a`
# [1] 3
# $b
# [1] 3
# $d
# [1] "Hello"
# $e
[1] NA
从列表中删除多个元素
my_list[c(-1,-3,-2)]
# $`d`
# [1] "Hello"
# $e
# [1] NA
my_list[c(-3:-5)]
# $`a`
# [1] 3
# $b
# [1] 3
my_list[-seq(1:2)]
# $`c`
# [1] 4
# $d
# [1] "Hello"
# $e
# [1] NA
有一个rlist包(http://cran.r-project.org/web/packages/rlist/index.html)可用于处理各种列表操作。
示例(http://cran.r-project.org/web/packages/rlist/vignettes/Filtering.html):
library(rlist)
devs <-
list(
p1=list(name="Ken",age=24,
interest=c("reading","music","movies"),
lang=list(r=2,csharp=4,python=3)),
p2=list(name="James",age=25,
interest=c("sports","music"),
lang=list(r=3,java=2,cpp=5)),
p3=list(name="Penny",age=24,
interest=c("movies","reading"),
lang=list(r=1,cpp=4,python=2)))
list.remove(devs, c("p1","p2"))
结果为:
# $p3
# $p3$name
# [1] "Penny"
#
# $p3$age
# [1] 24
#
# $p3$interest
# [1] "movies" "reading"
#
# $p3$lang
# $p3$lang$r
# [1] 1
#
# $p3$lang$cpp
# [1] 4
#
# $p3$lang$python
# [1] 2
我不知道你是否还需要对此问题的答案,但是从我有限的(3周的自学R)R经验中发现,在像for循环这样动态更新列表的情况下,使用NULL
赋值实际上是错误或次优的。
更准确地说,使用
myList[[5]] <- NULL
将会抛出错误
myList[[5]] <- NULL:替换长度为零
或者
提供的元素数量超过要替换的元素数量
我发现更加稳定的做法是
myList <- myList[[-5]]
[[-5]]
应该改成单方括号,否则你只是取消选择该列表元素的内容,而不是元素本身。至少使用双方括号会给我这个错误:“尝试选择多个元素”。对我有效的是:myList <- myList[-5]
。 - n1k31t4我想快速补充一下(因为我没有在任何答案中看到这个),对于命名列表,你也可以使用l["name"] <- NULL
。例如:
l <- list(a = 1, b = 2, cc = 3)
l['b'] <- NULL