仅合并来自 R 中不同数据帧的一两列

jal*_*lsa 5 merge r

我有两组数据框。下面是每个的前五行。

First Data frame Name: sampel_sort
name                             id         supplier   usage
ABC                             10000079    811121     1
DEF                             10000182    541513     4
Supplier C                      10000484    531110     1
Supplier D                      10000523    541320     1
Supplier E                      10000592    524210     1
Supplier F                      10012711    237110     1

Second data frame Name: MBE
  id    State   total   CATEGORY
10000070    MD       5       MBE
10000182    PR       14      MBE
10000484    TX       1       MBE
10000526    MI       3       MBE
10000592    FL       1       MBE
10000680    ID       14      MBE
Run Code Online (Sandbox Code Playgroud)

我的实际数据集有更多的列。我想组合两个数据框,但只想导入类别列。以下合并语句有效:

ncombined <- merge(x = sample_sort, y = MBE, by = "id", all.x = TRUE)
Run Code Online (Sandbox Code Playgroud)

但这给了我 MBE 数据集中的所有列。我以不同的方式尝试了以下操作(以便仅导入类别列)。但我没有任何运气。我收到一个错误

ncombined <- merge(x = sample_sort, y = MBE[,c("CATEGORY")], by = "id", all.x = TRUE)
Run Code Online (Sandbox Code Playgroud)

fix.by(by.y, y) 中的错误:“by”必须指定唯一有效的列

最终结果应如下所示:

First Data frame Name: sample_sort
name                             id         supplier   usage  CATEGORY
ABC                             10000079    811121     1       MBE
DEF                             10000182    541513     4       MBE
Supplier C                      10000484    531110     1       MBE
Supplier D                      10000523    541320     1       MBE
Supplier E                      10000592    524210     1       MBE
Supplier F                      10012711    237110     1       NA
Run Code Online (Sandbox Code Playgroud)

Dav*_*vid 2

尝试在合并之前取出列,例如

ncombined <- merge(x = sample_sort, y = MBE[,c(1:4)], by = "id", all.x = TRUE)
Run Code Online (Sandbox Code Playgroud)