我想用ID和Product替换一个数据框中的行和另一个数据框中的行。我尝试过使用merge,但我只剩下合并的行。有没有办法合并/替换,以便我的数据集看起来像下面的那样?
library(data.table)
DF <- as.data.table(list(ID = c(1,2,3,4,5), Product = c('Y', 'W', 'N', 'Z', 'A'), Type = c(2, 4, 5, 7, 4)))
DF
ID Product Type
1 Y 2
2 W 4
3 N 5
4 Z 7
5 A 4
和
DF2 <- as.data.table(list(ID = c(1,2,3), Product = c('Y','W','N'), Category = c(1, 1, 5)))
DF2
ID Product Category
1 Y 1
2 W 1
3 N 5
我想看起来像:
ID Product Type Category
1 Y 2 1
2 W 4 1
3 N 5 5
4 Z 7 NA
5 A 4 NA
我的代码:
merge(DF, DF2, by=c('ID', 'Product'))
答案 0 :(得分:2)
试试这个
library(data.table)
DF <- as.data.table(list(ID = c(1,2,3,4,5), Product = c('Y', 'W', 'N', 'Z', 'A'), Type = c(2, 4, 5, 7, 4)))
DF2 <- as.data.table(list(ID = c(1,2,3), Product = c('Y', 'W', 'N'), Category = c(1, 1, 5)))
merge(DF, DF2, by=c("ID","Product"), all.x=TRUE)