これを行う通常の方法は、with()
に式を(より正確には式を)ラップすることです。結果のベクトルを生成する場合は、with
クロージャによって作成された環境のコンテキストで各式を評価(評価)する必要があります。
expr <- expression(365/(x/y),
365/(x/(y + z)),
365/(x/ (y - z)),
c + d + e + f)
dat <- data.frame(x=sample(1:100, 10),
y=sample(1:100, 10),
z=sample(1:100, 10),
c=sample(1:100, 10),
d=sample(1:100, 10),
e=sample(1:100, 10),
f=sample(1:100, 10))
sapply(expr, function(ep) with(dat, eval(ep)))
[,1] [,2] [,3] [,4]
[1,] 121.66667 1155.8333 -912.50000 168
[2,] 4197.50000 4471.2500 3923.75000 131
[3,] 290.00000 620.0000 -40.00000 219
[4,] 60.83333 3224.1667 -3102.50000 245
[5,] 6752.50000 24637.5000 -11132.50000 229
[6,] 4901.42857 7456.4286 2346.42857 239
[7,] 127.75000 246.3750 9.12500 177
[8,] 355.64103 1179.2308 -467.94872 142
[9,] 500.18519 959.8148 40.55556 161
[10,] 299.48718 444.5513 154.42308 194