r - data.table join 然后将一个表中的所有列添加到另一个

标签 r data.table

我的问题和这个问题基本一样:data.table join then add columns to existing data.frame without re-copy .

基本上我有一个带键的模板,我想通过相同的键将其他 data.tables 中的列分配给模板。

> template
    id1 id2
 1:   a   1
 2:   a   2
 3:   a   3
 4:   a   4
 5:   a   5
 6:   b   1
 7:   b   2
 8:   b   3
 9:   b   4
10:   b   5
> x
   id1 id2       value
1:   a   2  0.01649728
2:   a   3 -0.27918482
3:   b   3  0.86933718
> y
   id1 id2     value
1:   a   4 -1.163439
2:   b   4  2.267872
3:   b   5  1.083258
> template[x, value := i.value]
> template[y, value := i.value]
> template
    id1 id2       value
 1:   a   1          NA
 2:   a   2  0.01649728
 3:   a   3 -0.27918482
 4:   a   4 -1.16343917
 5:   a   5          NA
 6:   b   1          NA
 7:   b   2          NA
 8:   b   3  0.86933718
 9:   b   4  2.26787248
10:   b   5  1.08325793
> 

但如果 xy已经说100列,那么就不可能写出value := i.value所有列的语法。有没有办法对 x 中的所有列做同样的事情?和 y ?

编辑:
如果我这样做 y[x[template]] ,然后它会创建单独的 value列,不打算:
> y[x[template]]
    id1 id2     value     value.1
 1:   a   1        NA          NA
 2:   a   2        NA  0.01649728
 3:   a   3        NA -0.27918482
 4:   a   4 -1.163439          NA
 5:   a   5        NA          NA
 6:   b   1        NA          NA
 7:   b   2        NA          NA
 8:   b   3        NA  0.86933718
 9:   b   4  2.267872          NA
10:   b   5  1.083258          NA
> 

最佳答案

只需创建一个将名称作为参数并为您构造表达式的函数。然后 eval它每次通过传递每个 data.table 的名称你需要。这是一个插图:

get_expr <- function(x) {
    # 'x' is the names vector
    expr = paste0("i.", x)
    expr = lapply(expr, as.name)
    setattr(expr, 'names', x)
    as.call(c(quote(`:=`), expr))
}

> get_expr('value')    ## generates the required expression
# `:=`(value = i.value)

template[x, eval(get_expr("value"))]
template[y, eval(get_expr("value"))]

#     id1 id2       value
#  1:   a   1          NA
#  2:   a   2  0.01649728
#  3:   a   3 -0.27918482
#  4:   a   4 -1.16343900
#  5:   a   5          NA
#  6:   b   1          NA
#  7:   b   2          NA
#  8:   b   3  0.86933718
#  9:   b   4  2.26787200
# 10:   b   5  1.08325800

关于r - data.table join 然后将一个表中的所有列添加到另一个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22767843/

相关文章:

r - 使用 apply 和 data.table 在 R 中自动进行 num-to-char 转换

r - 使用 `data.table` 根据变量获取第一个子组

r - 在 R 中将不规则数据转换为可用格式

r - Data.Table 非对等连接与算术运算

r - R 中数字的逗号分隔符?

识别向量中的给定模式并添加缺少的元素以获得给定模式的重复

r - 在 R 中对 ARIMA AIC 进行排序

r - 扩展将 data.table 作为参数的函数以使用完整表(而不是子集)

r - 页面加载时 Shiny 的 submitButton 行为

r - 如何根据 Excel 电子表格中重复标题的值在 R 中创建新列?