我有一个数据框“ z”
letter color
1 a 0
2 e 0
3 b 0
4 b 0
5 d 0
6 d 0
7 a 0
8 b 0
9 c 0
10 d 0
11 c 0
12 c 0
13 c 0
14 c 0
15 e 0
16 e 0
17 a 0
18 d 0
19 e 0
20 b 0
和另一个数据框“ y”
letter color
1 a red
2 b blue
3 c green
当z中的字母与y中的字母匹配时,我想将y中的颜色附加到z中相应的颜色字段中,但是我不想从z中删除任何值。如果没有匹配,则z $ color应该保持不变。我在z $ color中使用“ 0”作为占位符,这可以是文本。
我一直在尝试使用%in%进行循环,match()命令和语句,但是我还没有完全达到我想要的结果。
有任何想法吗?
这是我用于数据帧的代码
set.seed(3)
z=data.frame(sample(c("a","b","c","d","e"),20,replace=T))
names(z)="letter"
z$color=rep(0,dim(z)[1])
z
y1=c("a","b","c")
y2=c("red","blue","green")
y=data.frame(cbind(y1,y2))
names(y)=c("letter","color")
y
如果您z$color
只需要占位符,则无需首先使用,NA
以后可以替换为0
z$color<-y[match(z$letter, y$letter),2]
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句