使用另一个数据框的匹配值向数据框添加新列 [英] Add a new column to a dataframe using matching values of another dataframe

查看:19
本文介绍了使用另一个数据框的匹配值向数据框添加新列的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试用与表2的val2值匹配的值填充表1

table1$New_val2 = table2[table2$pid==table1$pid,]$val2

但我收到警告

longer object length is not a multiple of shorter object length

这已经足够公平了,因为桌子长度不一样。

请指导我正确的操作方法。

推荐答案

merge(table1, table2[, c("pid", "val2")], by="pid")

添加all.x=TRUE参数,以便将表1中没有匹配项的所有PID保留在表2中.

你在正确的轨道上。以下是使用匹配的方法.

table1$val2 <- table2$val2[match(table1$pid, table2$pid)]

这篇关于使用另一个数据框的匹配值向数据框添加新列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆