我有一个有很多参数的函数:
乐趣(A,B,C,d,E)
现在,我想将固定值a,b,c,d
分配给A,B,C,D
,并为E分配1:7的列表
我想使用do.call()
,如下所示,但它不起作用。
a <- do.call(function(x) fun(A = a, B = b, C = c, D = d, E = x), list(1:7))
我转向lapply,它有效,
a <- lapply(c(1:7), function(x) fun(A = a, B = b, C = c, D = d, E = x))
作为约书亚乌尔里希的回答,当我尝试
时a `<- do.call(fun, list(A = a, B = b, C = c, D = d, E = list(1:7)))`
它说
(list) object cannot be coerced to type 'double'
所以我觉得有趣的是E需要一个double值,但是do.call()并没有逐个给出值,而是列表。
我不想使用lapply
,因为它会返回一个列表列表,如果我想指向一个特殊列表,我必须使用[[]],并且只能使用单个值允许在[[]]中,我不能使用向量指向,例如[[a]],&lt; -c(1:7)。
如何让do.call()工作?
答案 0 :(得分:3)
应该是:
a <- do.call(fun, list(A = a, B = b, C = c, D = d, E = list(1:7)))
我有一种感觉,你希望E
成为一个向量,而不是一个列表,在这种情况下它应该是:
a <- do.call(fun, list(A = a, B = b, C = c, D = d, E = 1:7))