我遇到了以下问题
vec <- c("a11","b21","c31")
df <- data.frame(a = c(0,0,0), b = c(1,1,1), row.names = vec)
df["a",]
returns
df["a",]
a b
a11 0 1
However,
"a" %in% vec
and
"a" %in% rownames(df)
两者都返回 False
当使用字母后跟数字作为行名称时,R 允许部分匹配字符串。我已在 R v3.2.2 和 R v3.2.1 上复制了此内容。
甚至
df[["a",1,exact=T]]
返回 0。
我可以设置什么以使 R 不允许这种部分匹配吗?
奇怪的是,甚至没有意识到部分匹配是一件事。
您可以尝试单独识别与 rowname 完全匹配的记录,并根据结果构建索引向量,而不是直接索引到数据帧,如下所示:
> ix <- 'a' == row.names(df)
> df[ix,]
<0 rows> (or 0-length row.names)
或等效的(但更简洁):
> df['a' == row.names(df),]
或者,如果将对象强制到 data.table,它将仅返回精确匹配:
> library(data.table)
> dt <- data.table(df)
> dt[,ix := vec]
> setkey(dt, ix)
> dt['a']
a b ix
1: NA NA a
> dt['a11']
a b ix
1: 0 1 a11
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)