使用merge可以将数据框按照行名合并
df1 = data.frame(CustomerId = c(1:6), Product = c(rep("Toaster", 3), rep("Radio", 3)))
rownames(df1)<-c("a", "b", "c", "d", "e", "f")
df2 = data.frame(CustomerId = c(2, 4, 6), State = c(rep("Alabama", 2), rep("Ohio", 1)))
rownames(df2)<-c("c","e","f")
df1:
data:image/s3,"s3://crabby-images/b61bb/b61bbe9ee63f56ddbd77458d452a94864b115ba6" alt=""
df2:
data:image/s3,"s3://crabby-images/62c7f/62c7f0e3678b82d60616c73b94c289d80c6a760d" alt=""
按照列名合并,并输出所有:
df3<-merge(df1, df2, by = "row.names", all = T)
df3
data:image/s3,"s3://crabby-images/fcd69/fcd69527b7b01df01f281309062da7ed2d93dc45" alt=""
将all改为FALSE会只输出行名相等的行:
data:image/s3,"s3://crabby-images/fefd0/fefd0484b3350d2bade7dfc92d9184fa4b933ea6" alt=""
网友评论