목록에서 요소를 제거하려면 어떻게 해야 합니까?
목록이 있으며 목록에서 하나의 요소를 제거하려고 합니다.이거 어떻게 해?
레퍼런스 매뉴얼에 이 기능의 명확한 이름이 기재되어 있을 것으로 생각되는 것을 찾아봤지만, 적절한 이름을 찾을 수 없었습니다.
예를 들어 요소를 제거한 목록을 함수에 전달하는 경우 목록을 수정하지 않으려면 인덱스를 사용할 수 있습니다. 음의 인덱스는 "이 요소를 포함하지 않음"을 의미합니다.
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
R은 전혀 모릅니다만, 크리에이티브한 구글링에 의해서, 이쪽이 되었습니다.http://tolstoy.newcastle.edu.au/R/help/05/04/1919.html
여기서 중요한 인용구는 다음과 같습니다.
목록에서 요소를 삭제하는 방법에 대한 R의 명시적인 문서는 찾을 수 없지만 시행착오를 통해 알 수 있습니다.
myList [ [ 5 ]< - 특수한 순서
5번째 요소를 제거한 후 해당 요소의 삭제로 인해 발생한 구멍을 닫습니다.그러면 지수값으로 충분하기 때문에 요소들을 떨어뜨릴 때 조심해야 합니다.나는 명단의 맨 뒷부분부터 맨 앞부분까지 일을 해야 한다.
이 투고에 대한 응답은 스레드 후반부에서 다음과 같습니다.
목록의 요소를 삭제하려면 R FAQ 7.1을 참조하십시오.
R FAQ의 관련 섹션에는 다음과 같이 기재되어 있습니다.
... x[i] 또는 x[i]를 NULL로 설정하지 마십시오.이렇게 하면 대응하는 컴포넌트가 목록에서 삭제되기 때문입니다.
(약간 거꾸로) 요소를 제거하는 방법을 알 수 있습니다.
이름 있는 리스트라면 간단히 사용할 수 있다는 것을 덧붙이고 싶습니다.within
.
l <- list(a = 1, b = 2)
> within(l, rm(a))
$b
[1] 2
그러면 원래 목록을 덮어쓸 수 있습니다.
l <- within(l, rm(a))
명명된 요소를 제거하다a
리스트에서l
.
다음으로 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))]
건배.
이름 있는 목록이 있고 특정 요소를 삭제하려면 다음을 수행합니다.
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
R하여 R을(3주치) 찾았다NULL
특히 for-loop과 같은 방법으로 목록을 동적으로 업데이트할 경우 할당이 잘못되었거나 최적이지 않습니다.
좀 더 정확히 말하면
myList[[5]] <- NULL
에러가 발생합니다.
myList [ [ 5 ]< - NULL : 치환의 길이가0 입니다
또는
교환할 수 있는 것보다 더 많은 요소가 공급된다
제가 좀 더 일관되게 일한다는 걸 알게 된 건
myList <- myList[[-5]]
(되어 있지 에) 있는 리스트에 도 할 수 것을 합니다.l["name"] <- NULL
§:
l <- list(a = 1, b = 2, cc = 3)
l['b'] <- NULL
이름 있는 목록의 경우 이러한 도우미 기능이 유용합니다.
member <- function(list,names){
## return the elements of the list with the input names
member..names <- names(list)
index <- which(member..names %in% names)
list[index]
}
exclude <- function(list,names){
## return the elements of the list not belonging to names
member..names <- names(list)
index <- which(!(member..names %in% names))
list[index]
}
aa <- structure(list(a = 1:10, b = 4:5, fruits = c("apple", "orange"
)), .Names = c("a", "b", "fruits"))
> aa
## $a
## [1] 1 2 3 4 5 6 7 8 9 10
## $b
## [1] 4 5
## $fruits
## [1] "apple" "orange"
> member(aa,"fruits")
## $fruits
## [1] "apple" "orange"
> exclude(aa,"fruits")
## $a
## [1] 1 2 3 4 5 6 7 8 9 10
## $b
## [1] 4 5
.extract
의 function의 magrittr
패키지를 클릭하여 목록 항목을 제거합니다.
a <- seq(1,5)
b <- seq(2,6)
c <- seq(3,7)
l <- list(a,b,c)
library(magrittr)
extract(l,-1) #simple one-function method
[[1]]
[1] 2 3 4 5 6
[[2]]
[1] 3 4 5 6 7
lapply 및 grep 사용:
lst <- list(a = 1:4, b = 4:8, c = 8:10)
# say you want to remove a and c
toremove<-c("a","c")
lstnew<-lst[-unlist(lapply(toremove, function(x) grep(x, names(lst)) ) ) ]
# or
pattern<-"a|c"
lstnew<-lst[-grep(pattern, names(lst))]
# or
lst %>% purrr::discard(names(.) == "a") # use %in% for a set
가 있습니다.purrr
다음 중 하나:
pluck
★★★★★★★★★★★★★★★★★」assign_in
는, 된 값에 해, 할 수 .이름이나 인덱스를 조합하면 액세스 할 수 있습니다.
library(purrr)
l <- list("a" = 1:2, "b" = 3:4, "d" = list("e" = 5:6, "f" = 7:8))
# select values (by name and/or index)
all.equal(pluck(l, "d", "e"), pluck(l, 3, "e"), pluck(l, 3, 1))
[1] TRUE
# or if element location stored in a vector use !!!
pluck(l, !!! as.list(c("d", "e")))
[1] 5 6
# remove values (modifies in place)
pluck(l, "d", "e") <- NULL
# assign_in to remove values with name and/or index (does not modify in place)
assign_in(l, list("d", 1), NULL)
$a
[1] 1 2
$b
[1] 3 4
$d
$d$f
[1] 7 8
지우다를 사용해서 값을 도 있어요.modify_list
「」를 할당하는 으로,zap()
★★★★★★★★★★★★★★★★★」NULL
:
all.equal(list_modify(l, a = zap()), list_modify(l, a = NULL))
[1] TRUE
하다, 하다, 하다, 하다, 하다의 술어 함수를 하여 요소를 할 수 .discard
★★★★★★★★★★★★★★★★★」keep
:
# remove numeric elements
discard(l, is.numeric)
$d
$d$e
[1] 5 6
$d$f
[1] 7 8
# keep numeric elements
keep(l, is.numeric)
$a
[1] 1 2
$b
[1] 3 4
다음은 Base R을 사용하여 수행할 수 있는 간단한 솔루션입니다.원래 번호 목록에서 숫자 5를 삭제합니다.같은 방법을 사용하여 목록에서 원하는 요소를 제거할 수 있습니다.
#the original list
original_list = c(1:10)
#the list element to remove
remove = 5
#the new list (which will not contain whatever the `remove` variable equals)
new_list = c()
#go through all the elements in the list and add them to the new list if they don't equal the `remove` variable
counter = 1
for (n in original_list){
if (n != ){
new_list[[counter]] = n
counter = counter + 1
}
}
new_list
5번으로 나누다
new_list
# [1] 1 2 3 4 6 7 8 9 10
이건 어때?다시, 인덱스 사용
> m <- c(1:5)
> m
[1] 1 2 3 4 5
> m[1:length(m)-1]
[1] 1 2 3 4
또는
> m[-(length(m))]
[1] 1 2 3 4
하시면 됩니다.which
.
x<-c(1:5)
x
#[1] 1 2 3 4 5
x<-x[-which(x==4)]
x
#[1] 1 2 3 5
숫자 인덱스를 피하고 싶다면
a <- setdiff(names(a),c("name1", ..., "namen"))
을 namea...namen
은 됩니다. 이치노
> l <- list(a=1,b=2)
> l[setdiff(names(l),"a")]
$b
[1] 2
벡터뿐만 아니라
> v <- c(a=1,b=2)
> v[setdiff(names(v),"a")]
b
2
언급URL : https://stackoverflow.com/questions/652136/how-can-i-remove-an-element-from-a-list
'programing' 카테고리의 다른 글
행과 열 번호가 지정된 셀의 내용을 가져옵니다. (0) | 2023.04.21 |
---|---|
EXECUTE 권한이 사용자 정의 테이블 유형에 대해 거부되었습니까? (0) | 2023.04.21 |
Swift 열거형 카운트를 얻으려면 어떻게 해야 합니까? (0) | 2023.04.16 |
신속한 언어로 구조화 vs 클래스 (0) | 2023.04.16 |
데이터베이스에 저장된 모든 프로시저에 대해 사용자에게 실행 권한을 부여하시겠습니까? (0) | 2023.04.16 |