Итерации по парам ключ/значение из списка()

Я хотел бы знать, как я могу перебирать пару ключ/значение из объекта списка в R, как показано ниже:

toto <- list(a="my name is",b="I'm called",c="name:")
myfun <- function(key,value) paste(value,key)
for( key in names(toto) ) toto[key] <- myfun(key,toto[[key]])

Есть ли способ избежать цикла for (используя lapply() или такой). Было бы быстрее?

Спасибо!

Ответы

Ответ 1

Лучшее решение для всех - просто вызвать paste напрямую без цикла (он уже векторизован):

> paste(toto, names(toto))
[1] "my name is a" "I'm called b" "name: c"  

Аналогичный вопрос ранее заданный в R-Help, с несколькими креативными решениями. lapply не может отображать имена внутри функции. Эта функция была предоставлена ​​Романом Франсуа на основе чего-то Томаса Ламли:

yapply <- function(X,FUN, ...) { 
  index <- seq(length.out=length(X)) 
  namesX <- names(X) 
  if(is.null(namesX)) 
    namesX <- rep(NA,length(X))

  FUN <- match.fun(FUN) 
  fnames <- names(formals(FUN)) 
  if( ! "INDEX" %in% fnames ){ 
    formals(FUN) <- append( formals(FUN), alist(INDEX=) )   
  } 
  if( ! "NAMES" %in% fnames ){ 
    formals(FUN) <- append( formals(FUN), alist(NAMES=) )   
  } 
  mapply(FUN,X,INDEX=index, NAMES=namesX,MoreArgs=list(...)) 
}

Вот пример использования:

> yapply(toto, function( x ) paste(x, NAMES) )
             a              b              c 
"my name is a" "I'm called b"      "name: c" 

Ответ 2

Это должно сделать это за вас:

do.call(paste, list(toto, names(toto) ))