R data.table: ¿Cómo puedo fusionar una lista de data.tables? [duplicar]

Dec 11 2020

Tengo una larga lista de tablas de datos. Quiero fusionarlos (combinación interna) todos en un solo data.table.

Con dplyry purrrpuedo hacer:

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')

¿Cómo puedo hacer esto con data.table?

Respuestas

2 akrun Dec 11 2020 at 01:11

Podemos usar join on

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