R data.table:data.tablesのリストをマージするにはどうすればよいですか?[複製]

Dec 11 2020

data.tablesの長いリストがあります。それらすべてを1つのdata.tableにマージ(内部結合)したいと思います。

dplyrし、purrr私が行うことができます。

dt1 <- data.table(cbind(letters[1:10], 1:10))
dt2 <- data.table(cbind(letters[3:12], 3:12))
dt3 <- data.table(cbind(letters[5:15], 5:15))

dtl <- list(dt1, dt2, dt3)

library(dplyr)
library(purrr)
merged <- dtl %>% reduce(inner_join, by='V1')

data.tableでこれを行うにはどうすればよいですか?

回答

2 akrun Dec 11 2020 at 01:11

結合を使用できます on

library(data.table)
na.omit(Reduce(function(x, y) x[y, on = .(V1)], dtl))