r - 根据公共(public)列组合 R 中的两个数据框

标签 r merge

我必须合并两个看起来像这样的数据框 我想采用数据框之间的公共(public)列并将它们连接在一起。 两个数据框中的行将完全不同。

      a  b c 
row1  1  0 1      
row2  1  0 1

另一个数据框

     d a c f
row3 1 0 1 1
row4 1 1 0 0 

我希望最终的数据集看起来像这样

        a c 
row1    1 1
row2    1 1
row3    0 1
row4    1 0

这是来自两个数据帧的输出

dput(x1)
structure(list(d = c(1L, 1L), a = 0:1, c = c(1L, 0L), f = c(1L, 
0L)), .Names = c("d", "a", "c", "f"), row.names = c("row3", "row4"
), class = "data.frame")

dput(x2)
structure(list(a = c(1L, 1L), b = c(0L, 0L), c = c(1L, 1L)), .Names = c("a", 
"b", "c"), row.names = c("row1", "row2"), class = "data.frame")

最佳答案

您可以获得通用名称,然后使用行绑定(bind):

common <- intersect(names(x1), names(x2))
rbind(x1[,common], x2[,common])
     a c
row3 0 1
row4 1 0
row1 1 1
row2 1 1

编辑:匹配您的预期输出

 rbind(x2[,common], x1[,common])
     a c
row1 1 1
row2 1 1
row3 0 1
row4 1 0

关于r - 根据公共(public)列组合 R 中的两个数据框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16674377/

相关文章:

algorithm - 以下合并算法的时间复杂度是多少?

r - 高效合并大型 data.tables

mysql - 如何将 MS SQL 合并查询转换为与 MySQL 数据库一起使用?

r - 在堆积条形图中悬停时 plotly 给出不正确的文本

r - 提高 FFT 的循环速度

join - 将制表符分隔的文本文件合并到单个文件中

arrays - 合并两个 numpy 数组

r - 从 R 中的字符串到 DataFrame 的词频

r - 如何标记合并数据框

r - 为什么使用 caret::train(..., method = "rpart") 的结果与 rpart::rpart(...) 不同?