我需要使用只使用 data.table库进行一些设置操作。
我不想加入/合并,而是设置操作。因此,我们不按键匹配列,而是添加来自不同data.tables的行。
我们从内置数据集中提取两个样本。
以下是所有有问题的问题:
#install.packages("nycflights13")
library(nycflights13)
#install.packages("sqldf")
library(sqldf)
#install.packages("data.table")
library(data.table)
dt_airports <- data.table(airports)
Adt <- dt_airports[1:10]
Bdt <- dt_airports[6:15]
sqldf('SELECT * FROM A INTERSECT SELECT * FROM B')
# can I do it better using data.table?
rbindlist(list(Adt,Bdt))[duplicated(rbindlist(list(Adt,Bdt))),]
sqldf('SELECT * FROM A EXCEPT SELECT * FROM B')
# how to do it using data.table?
sqldf('SELECT * FROM B EXCEPT SELECT * FROM A')
# how to do it using data.table?发布于 2016-11-07 13:42:23
只使用data.table:
sqldf('SELECT * FROM A INTERSECT SELECT * FROM B')
# data.table
rbindlist(list(Adt,Bdt))[duplicated(rbindlist(list(Adt,Bdt))),]
# better in data.table
setkeyv(Adt,colnames(Adt)[1:7])
Adt[Bdt, nomatch=0L]
sqldf('SELECT * FROM A EXCEPT SELECT * FROM B')
# data.table
setkeyv(Adt,colnames(Adt)[1:7])
Adt[!Bdt]
sqldf('SELECT * FROM B EXCEPT SELECT * FROM A')
# data.table
setkeyv(Bdt,colnames(Bdt)[1:7])
Bdt[!Adt]https://stackoverflow.com/questions/40465388
复制相似问题