首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在R中合并这两个数据集

如何在R中合并这两个数据集
EN

Stack Overflow用户
提问于 2015-07-22 18:09:17
回答 2查看 76关注 0票数 0

我如何合并这两个数据集,以便填充N/A。

示例->

代码语言:javascript
复制
Name Abbreviation Denomination
-------------------------------
Asia     A             N/A
Bob      B             N/A
Chris    C             N/A
David    D             N/A

与…合并

代码语言:javascript
复制
Name Abbreviation Denomination
-------------------------------
Asia     A             5
Bradley  BA            1
Chris    C             7
David    D             9
Emma     EM            2
Soo      So            4
Nate     NT            2
Bob      B             1
Brat     B             5
Asia     S             2

如何将这两组合并,以便获得:

代码语言:javascript
复制
Name Abbreviation Denomination
-------------------------------
Asia     A             5
Bob      B             1
Chris    C             7
David    D             9
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-07-22 18:18:56

我认为有一种聪明的方法可以做到这一点,但下面是我笨拙的解决方案:

代码语言:javascript
复制
 df3 <- merge(df1, df2, by = c("Name", "Abbreviation"))
 df3
   Name Abbreviation Denomination.x Denomination.y
1  Asia            A            N/A              5
2   Bob            B            N/A              1
3 Chris            C            N/A              7
4 David            D            N/A              9

,然后删除列Denomination.xdf3 <- df3[, -3]

代码语言:javascript
复制
df3
   Name Abbreviation Denomination.y
1  Asia            A              5
2   Bob            B              1
3 Chris            C              7
4 David            D              9
票数 1
EN

Stack Overflow用户

发布于 2015-07-22 18:18:41

试试这个:

代码语言:javascript
复制
x <- data.frame(Name = c("Asia", "Bradley", "Chris", "David", "Emma", "Soo", "Nate", 
                     "Bob", "Brat", "Asia"),
            Abb = c("A", "BA", "C", "D", "EM", "So", "NT", "B", "B", "S"),
            Den = c(5, 1, 7, 9, 2, 4, 2, 1, 5, 2))

y <- data.frame(Name = c("Asia", "Bob", "Chris", "David"), Abb = c("A","B", "C", "D"),
            Den = c("NA", "NA", "NA", "NA"))

data_df <- merge(x, y , by = 1)

subset(data_df, Abb.x != "S", c(1,2,3))


     Name Abb.x Den.x
  1  Asia     A     5
  3   Bob     B     1
  4 Chris     C     7
  5 David     D     9

您可以将列等重命名为任何您想要的名称。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31570836

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档