假设我有一个像这样的数据框:

df <- data.frame (id = c("a", "b", "a", "c", "e", "d", "e"), n=1:7)

和一个具有如下所示ID的向量:
v <- c("a", "b")

如何选择与v中的ID匹配的数据框的行?我不能将id列用于行名,因为它们不是唯一的。当我尝试这样做时,我得到:
 rownames(df) <- df[["id"]]
Error in `row.names<-.data.frame`(`*tmp*`, value = c(1L, 2L, 1L, 3L, 5L,  :
  duplicate 'row.names' are not allowed
In addition: Warning message:
non-unique values when setting 'row.names': ‘a’, ‘e’

最佳答案

这应该做您想要的:

ndx = which(df$id %in% v)
df[ndx,]

关于r - 通过非唯一ID选择数据帧的子集,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2568840/

10-12 17:05
查看更多