在此先感谢,如果这个问题之前已经回答过,我很抱歉 - 我已经看过很多了。我有一个数据集,其中包含一行连接信息,特别是:名称、颜色代码、一些函数表达式。例如,一个值可能是:
成本#FF0033@log(x)+6。
我拥有提取信息的所有代码,最后得到一个表达式向量,我想将其转换为实际函数列表。
例如:
func.list <- list()
test.func <- c("x","x+1","x+2","x+3","x+4")
其中 test.func 是表达式的向量。我想要的是:
func.list[[3]]
相当于
function(x){x+3}
我知道我可以使用以下方法创建一个函数:
somefunc <- function(x){eval(parse(text="x+1"))}
将字符值转换为函数。当我尝试循环创建多个功能时,问题就来了。对于我尝试过但不起作用的示例:
for(i in 1:length(test.func)){
temp <- test.func[i]
f <- assign(function(x){eval(expr=parse(text=temp))})
func.list[[i]] <- f
}
基于另一篇文章(http://stats.stackexchange.com/questions/3836/how-to-create-a-vector-of-functions)我也试过这个:
makefunc <- function(y){y;function(x){y}}
for(i in 1:length(test.func)){
func.list[[i]] <- assign(x=paste("f",i,sep=""),value=makefunc(eval(parse(text=test.func[i]))))
}
这给出了以下错误: eval 中的错误(expr,envir,enclos):找不到对象'x'
最终目标是获取函数列表并将第 j 个函数应用于 data.frame 的第 j 列,以便脚本用户可以指定如何规范化列标题给出的连接信息中的每一列。