Apply common function to all data frames and return data frames with same name

巧了我就是萌 提交于 2019-12-19 10:07:04

问题


I'm trying to apply a function to all similarly spelled data frames in my global environment in R. I want to apply this function to all these data frames, but I can't figure out how to do it without me specifying 1 by 1. I want to return the data frame to the global environment with the same spelling as it was before.

mtcars_test = mtcars
iris_test = iris
#....etc......could be 2 of them or 88 of them...but they will all end in "_test"

# figure out what data frames I am working with
list_of_my_dfs = lapply(ls(pattern = "*_test"), get)

#my function just multiples everything by 2
mytest_function = function(df){ df = df*2; return(df)}

helpme_return_these_dfs_to_outside_the_list=plyr::llply(list_of_my_dfs, mytest_function)

This is where I need help. I want to apply my function to each data frame within the list AND then 'return' the data frame from that list to my environment. So mtcars_test and all other data frames will be multiplied by 2 everywhere and returned back to global environment.


回答1:


1) environment subscripting Set e to the environment containing the data frames and then get their names and loop over them as shown:

BOD_test <- BOD  # not all columns of iris are numeric so use BOD instead
mtcars_test <- mtcars

e <- .GlobalEnv
nms <- ls(pattern = "_test$", envir = e)
for(nm in nms) e[[nm]] <- mytest_function(e[[nm]])

1a) assign An alternative to the last statement would be:

for(nm in nms) assign(nm, mytest_function( get(nm, e) ), e)

2) lists You might want, instead, to keep the data frames in a list:

L <- sapply(nms, get, envir = e, simplify = FALSE)
L[] <- lapply(L, mytest_function)

2a) sapply or if you do not want to overwrite L then:

sapply(L, mytest_function, simplify = FALSE)



回答2:


You can use eapply to iterate over an environment and then assign to store an object to your global environment. The function argument to eapply will be an anonymous function which first gets the df from global, assigning it to a temp variable, pass it to your function and then use assign to put it back to global.

I'd show you the code, but if you can't code this yourself you really shouldn't be doing it.



来源:https://stackoverflow.com/questions/39521038/apply-common-function-to-all-data-frames-and-return-data-frames-with-same-name

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!