替换或合并R?

时间:2016-08-25 23:12:07

标签: r replace merge

我想用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'))

1 个答案:

答案 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)