测试R中的向量中的值是否唯一

joa*_*oal 4 r vector unique

我们假设以下示例:

test<-c(1:5,3:7)
Run Code Online (Sandbox Code Playgroud)

这使

test
[1] 1 2 3 4 5 3 4 5 6 7
Run Code Online (Sandbox Code Playgroud)

我想有一个简单的函数,如果值在向量中是唯一的,则返回TRUE.

[1] TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE TRUE TRUE
Run Code Online (Sandbox Code Playgroud)

我尝试了什么:

unique(test)只给我一些独特的价值观,包括重复的价值观. duplicated(test)让我回来

[1] FALSE FALSE FALSE FALSE FALSE  TRUE  TRUE TRUE FALSE FALSE
Run Code Online (Sandbox Code Playgroud)

这显然不是必需的结果,因为函数按顺序测试重复观察,第一次出现不算作重复.我当然可以通过包含fromLast = T和创建两个向量来反转控制序列.在这两个中,我可以创建一个表示真正独特值的第三个......但这很复杂.

table(test) 允许我计算每个值的出现次数

test
1 2 3 4 5 6 7 
1 1 2 2 2 1 1 
Run Code Online (Sandbox Code Playgroud)

这让我更接近我想要的,但仍然不是必需的结果(一个相同长度的向量,表明它是否在向量中是唯一的.)


所以任何人都知道如何更容易地做到这一点?

CSJ*_*ell 7

匹配运算符%in%非常有用.

!test %in% test[duplicated(test)]
Run Code Online (Sandbox Code Playgroud)