如何检查向量是否包含给定值?
答案 0 :(得分:448)
match()
(返回第一个外观)和%in%
(返回布尔值)函数都是为此而设计的。
v <- c('a','b','c','e')
'b' %in% v
## returns TRUE
match('b',v)
## returns the first location of 'b', in this case: 2
答案 1 :(得分:159)
is.element()
使代码更具可读性,与%in%
v <- c('a','b','c','e')
is.element('b', v)
'b' %in% v
## both return TRUE
is.element('f', v)
'f' %in% v
## both return FALSE
subv <- c('a', 'f')
subv %in% v
## returns a vector TRUE FALSE
is.element(subv, v)
## returns a vector TRUE FALSE
答案 2 :(得分:66)
any()函数生成可读代码
> w <- c(1,2,3)
> any(w==1)
[1] TRUE
> v <- c('a','b','c')
> any(v=='b')
[1] TRUE
> any(v=='f')
[1] FALSE
答案 3 :(得分:43)
我将根据输出对选项进行分组。假设所有示例都有以下向量。
v <- c('z', 'a','b','a','e')
用于检查在线状态:
<强>%中%强>
> 'a' %in% v
[1] TRUE
<强>任何()强>
> any('a'==v)
[1] TRUE
<强> is.element()强>
> is.element('a', v)
[1] TRUE
查找首次出现:
<强>匹配()强>
> match('a', v)
[1] 2
查找所有出现的指数向量:
<强>其中()强>
> which('a' == v)
[1] 2 4
用于查找所有出现的逻辑向量 :
<强> == 强>
> 'a' == v
[1] FALSE TRUE FALSE TRUE FALSE
编辑: 从评论中提到的原因中删除 grep()和 grepl()
答案 4 :(得分:34)
您可以使用%in%
运算符:
vec <- c(1, 2, 3, 4, 5)
1 %in% vec # true
10 %in% vec # false
答案 5 :(得分:18)
还要找到元素的位置“哪个”可以用作
pop <- c(3,4,5,7,13)
which(pop==13)
并找到目标向量中未包含的元素,可以这样做:
pop <- c(1,2,4,6,10)
Tset <- c(2,10,7) # Target set
pop[which(!(pop%in%Tset))]
答案 6 :(得分:11)
为此,我非常喜欢grep()和grepl()。
grep()返回一个整数向量,表示匹配的位置。
yo <- c("a", "a", "b", "b", "c", "c")
grep("b", yo)
[1] 3 4
grepl()返回一个逻辑向量,匹配位置为“TRUE”。
yo <- c("a", "a", "b", "b", "c", "c")
grepl("b", yo)
[1] FALSE FALSE TRUE TRUE FALSE FALSE
这些功能区分大小写。