Как удалить элемент из списка?
У меня есть список, и я хочу удалить из него один элемент. Как я могу это сделать?
Я попытался взглянуть на то, что, по-моему, очевидные имена этой функции будут в справочном руководстве, и я не нашел ничего подходящего.
- Использование связанных данных, хранящихся в двумерном массиве
- Прокрутите список в WPF в определенную строку
- Как я могу получить список значений из dict?
- Как удалить повторяющиеся элементы из ArrayList?
- Java Сравните два списка
- Вызов метода активности из адаптера
- В чем разница между Set и List?
- Как читать текстовый файл в список или массив с помощью Python
- Как массивы на C # частично реализуют IList ?
- Ширина столбца CView ListView Auto
- Метод подсчета вхождений в список
- Как преобразовать список корневых ключей в словарь?
- Почему конечные запятые разрешены в списке?
Я вообще не знаю R, но немного творческого googling привело меня сюда: http://tolstoy.newcastle.edu.au/R/help/05/04/1919.html
Ключевая цитата оттуда:
Я не нашел явной документации для R о том, как удалить элементы из списков, но пробная версия и ошибка говорят мне
myList [[5]] <- NULL
удалит 5-й элемент и затем «закроет» отверстие, вызванное удалением этого элемента. Это наполняет значения индекса, поэтому я должен быть осторожным при удалении элементов. Я должен работать со спины списка на фронт.
Ответ на это сообщение позже в streamе гласит:
Для удаления элемента списка см. R FAQ 7.1
В соответствующем разделе R FAQ говорится:
… Не устанавливайте x [i] или x [[i]] в NULL, потому что это приведет к удалению соответствующего компонента из списка.
Что, кажется, говорит вам (несколько назад), как удалить элемент.
Надеюсь, что это поможет, или, по крайней мере, ведет вас в правильном направлении.
Если вы не хотите изменять список на месте (например, для передачи списка с элементом, удаленным для функции), вы можете использовать индексирование: отрицательные индексы означают «не включать этот элемент».
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"
Это также работает с dataframes:
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:
x <- list("a", "b", "c", "d", "e") x[length(x)] <- NULL
Если x может быть вектором, вам нужно будет создать новый объект:
x <- c("a", "b", "c", "d", "e") x <- x[-length(x)]
- Работа для списков и векторов
Удаление нулевых элементов из списка в одной строке:
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
)
Существует пакет 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, который, используя назначение NULL
самом деле является неправильным или малооптимальным, особенно если вы динамически обновляя список в чем-то вроде цикла for.
Точнее, используя
myList[[5]] <- NULL
выкинет ошибку
myList [[5]] <- NULL: замена имеет нулевую длину
или
больше элементов, чем есть, чтобы заменить
То, что я нашел для работы более последовательно,
myList <- myList[[-5]]
Я хотел бы добавить, что если это именованный список, вы можете просто использовать его within
.
l <- list(a = 1, b = 2) > within(l, rm(a)) $b [1] 2
Таким образом, вы можете перезаписать исходный список
l <- within(l, rm(a))
для удаления элемента с именем a
из списка l
.
Просто хотелось быстро добавить (потому что я не видел его ни в одном из ответов), что для именованного списка вы также можете сделать 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
Использование 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))]
Как насчет этого? Опять же, используя индексы
> 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