gpt4 book ai didi

r - 是否可以在 R 中以变量的形式在参数上传递 data.table 中的列名

转载 作者:行者123 更新时间:2023-12-04 09:53:19 24 4
gpt4 key购买 nike

我正在尝试对 data.table 执行非等值连接,如下所示:

A <- data.table(p = c(10, 20, 30), q = c(15, 25, 35), r = c(0, 0, 0))
B <- data.table(x = c(5, 15), y = c(15, 25), z = c(1, 2))

这有效:
A[B, on = .(p >= x, p < y), r := r + z]

这不起作用:
col_var <- "p"
A[B, on = .(col_var >= x, col_var < y), r := r + z]
or
A[B, on = .(.(col_var) >= x, .(col_var) < y), r := r + z]

我正在努力实现这样的目标:
col_var <- c("p", "q")
for(i in col_var)
{
A[B, on = .(.(i) >= x, .(i) < y), r := r + z]
}

当我直接使用 p 而不是 col_var 时,我能够得到结果,但我需要使用 for 循环,这要求我将列名存储在变量中。有没有办法可以使用存储在变量中的列名?

PS:我尝试使用 .(col_var) 但我收到错误“参数指定列指定不存在的列”

最佳答案

您可以在 on 中使用字符串争论。这允许我们使用 paste 构造连接。 :

A[B, on = paste(col_var, c(">= x", "< y")), r := r + z]

关于r - 是否可以在 R 中以变量的形式在参数上传递 data.table 中的列名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61980725/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com