Ho un elenco e desidero rimuovere un singolo elemento da esso. Come posso fare questo?
Ho provato a cercare ciò che penso che i nomi ovvi per questa funzione sarebbero nel manuale di riferimento e non ho trovato nulla di appropriato.
Ho un elenco e desidero rimuovere un singolo elemento da esso. Come posso fare questo?
Ho provato a cercare ciò che penso che i nomi ovvi per questa funzione sarebbero nel manuale di riferimento e non ho trovato nulla di appropriato.
Risposte:
Non conosco affatto R, ma un po 'di googling creativo mi ha portato qui: http://tolstoy.newcastle.edu.au/R/help/05/04/1919.html
La citazione chiave da lì:
Non trovo documentazione esplicita per R su come rimuovere elementi dagli elenchi, ma prova ed errore mi dice
myList [[5]] <- NULL
rimuoverà il 5 ° elemento e quindi "chiuderà" il foro causato dalla cancellazione di tale elemento. Questo soffoca i valori dell'indice, quindi devo stare attento a far cadere gli elementi. Devo lavorare dal retro dell'elenco in primo piano.
Una risposta a quel post in seguito nel thread indica:
Per eliminare un elemento di un elenco, vedere R FAQ 7.1
E la sezione pertinente della R FAQ dice:
... Non impostare x [i] o x [[i]] su NULL, poiché ciò rimuoverà il componente corrispondente dall'elenco.
Il che sembra dirti (in modo un po 'arretrato) come rimuovere un elemento.
Spero che ti aiuti, o almeno ti porti nella giusta direzione.
Error in list[length(list)] <- NULL : replacement has length zero
Se non si desidera modificare l'elenco sul posto (ad esempio per passare l'elenco con un elemento rimosso a una funzione), è possibile utilizzare l'indicizzazione: gli indici negativi significano "non includere questo elemento".
x <- list("a", "b", "c", "d", "e"); # example list
x[-2]; # without 2nd element
x[-c(2, 3)]; # without 2nd and 3rd
Inoltre, i vettori di indice logici sono utili:
x[x != "b"]; # without elements that are "b"
Funziona anche con i frame di dati:
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
questo modo, né è possibile rimuovere "b" da un elemento dell'elenco x[[2]] = c("b","k")
.
%in%
per il test su più articoli. Non sono sicuro di cosa intendi con "impossibile rimuovere x $ b" - intendi rimuovere l'intera colonna b
?
Ecco come rimuovere l'ultimo elemento di un elenco in R:
x <- list("a", "b", "c", "d", "e")
x[length(x)] <- NULL
Se x potrebbe essere un vettore, dovrai creare un nuovo oggetto:
x <- c("a", "b", "c", "d", "e")
x <- x[-length(x)]
Rimozione di elementi null da un elenco su una sola riga:
x=x[-(which(sapply(x,is.null),arr.ind=TRUE))]
Saluti
x
è un elenco vuoto. Utilizzare compact
da plyr
per questo compito, invece.
-(which(sapply(x,is.null),arr.ind=TRUE))
restituisce named integer(0)
che eliminerà completamente quella riga.
Vorrei aggiungere che se è un elenco di nomi che puoi semplicemente usare within
.
l <- list(a = 1, b = 2)
> within(l, rm(a))
$b
[1] 2
Quindi puoi sovrascrivere l'elenco originale
l <- within(l, rm(a))
per rimuovere l'elemento denominato a
dall'elenco l
.
within(l, rm(a, b))
Se hai un elenco di nomi e desideri rimuovere un elemento specifico, puoi provare:
lst <- list(a = 1:4, b = 4:8, c = 8:10)
if("b" %in% names(lst)) lst <- lst[ - which(names(lst) == "b")]
Questo farà una lista lst
con gli elementi a
, b
, c
. La seconda riga rimuove l'elemento b
dopo aver verificato che esiste (per evitare il problema menzionato da @hjv).
o meglio:
lst$b <- NULL
In questo modo non è un problema provare a eliminare un elemento inesistente (ad es. lst$g <- NULL
)
C'è il pacchetto rlist ( http://cran.r-project.org/web/packages/rlist/index.html ) per gestire vari tipi di operazioni dell'elenco.
Esempio ( 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"))
Risultati in:
# $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
Non so se hai ancora bisogno di una risposta a questo, ma ho scoperto dalla mia esperienza limitata (3 settimane di autoapprendimento R) con R che, l'uso del NULL
compito è in realtà sbagliato o subottimale, specialmente se stai aggiornando dinamicamente un elenco in qualcosa come un for-loop.
Per essere più precisi, usando
myList[[5]] <- NULL
genererà l'errore
myList [[5]] <- NULL: la sostituzione ha lunghezza zero
o
più elementi forniti di quanti ce ne siano da sostituire
Ciò che ho scoperto per funzionare in modo più coerente è
myList <- myList[[-5]]
[[-5]]
dovrebbero essere parentesi quadre singole, altrimenti si sta deselezionando solo il contenuto di quell'elemento elenco, non l'elemento stesso. Bene, almeno l'uso di parentesi quadre doppie mi dà questo errore: "tenta di selezionare più di un elemento". Ciò che funziona per me era allora: myList <- myList[-5]
.
Volevo solo aggiungere rapidamente (perché non l'ho visto in nessuna delle risposte) che, per un elenco di nomi, puoi anche fare l["name"] <- NULL
. Per esempio:
l <- list(a = 1, b = 2, cc = 3)
l['b'] <- NULL
Utilizzare -
(segno negativo) insieme alla posizione dell'elemento, ad esempio se si desidera rimuovere il 3 ° elemento utilizzarlo comeyour_list[-3]
Ingresso
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
Rimuovi singolo elemento dall'elenco
my_list[-3]
# $`a`
# [1] 3
# $b
# [1] 3
# $d
# [1] "Hello"
# $e
[1] NA
Rimuovi più elementi dall'elenco
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
Nel caso delle liste nominate trovo utili quelle funzioni di aiuto
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
Cosa ne pensi di questo? Ancora una volta, usando gli indici
> m <- c(1:5)
> m
[1] 1 2 3 4 5
> m[1:length(m)-1]
[1] 1 2 3 4
o
> m[-(length(m))]
[1] 1 2 3 4
m[1:(length(m) - 1)]
se vuoi evitare gli indici numerici, puoi usare
a <- setdiff(names(a),c("name1", ..., "namen"))
per cancellare i nomi namea...namen
da a. questo funziona per gli elenchi
> l <- list(a=1,b=2)
> l[setdiff(names(l),"a")]
$b
[1] 2
così come per i vettori
> v <- c(a=1,b=2)
> v[setdiff(names(v),"a")]
b
2