gpt4 book ai didi

r - 使用 R 合并不同排序的表

转载 作者:行者123 更新时间:2023-12-02 04:34:59 27 4
gpt4 key购买 nike

我有两张大 table 。一个包含标识符(未排序),另一个包含标识符列表(包含第一个表中的所有标识符)以及一个变量的关联值。我想向第一个表添加一列,其中包含第二个表中的关联值。有没有一种聪明的方法来继续使用 R 的已实现功能?

table 1
id
8979786
62782
6268768
6776566

table 2
id var
1 5
2 2
3 NA

9999999 6

结果应该是

table1
id var
8979786 5
62782 NA
6268768 7
4776566 4

提前致谢

最佳答案

那么 id 列同时存在于两个表中?您可以将它们合并在一起:merge(table1, table2, sort = FALSE)。有很多可供探索的合并选项,可让您模拟不同类型的联接,类似于 SQL 中的内联接、左联接、右联接和外联接。我在此处添加了附加参数 sort 以保留 table1 的原始顺序。

如果表 1 中有 ID,但表 2 中没有,并且您想要显示这些 NA,请添加 all.x = TRUE 作为参数。这相当于左连接。 all.y 是右联接,all = TRUE 相当于完全外联接。

可重现的示例:

> set.seed(1)
> table1 <- data.frame( id = sample(1:5, 5, FALSE))
> table1
id
1 2
2 5
3 4
4 3
5 1
> table2 <- data.frame( id = 1:5, var = rnorm(5))
> table2
id var
1 1 1.2724293
2 2 0.4146414
3 3 -1.5399500
4 4 -0.9285670
5 5 -0.2947204
> merge(table1, table2, sort = FALSE)
id var
1 2 0.4146414
2 5 -0.2947204
3 4 -0.9285670
4 3 -1.5399500
5 1 1.2724293

关于r - 使用 R 合并不同排序的表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5756442/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com