R語言數據去重

R語言經常使用的去重命令有unique duplicated數組

 

unique主要是返回一個把重複元素或行給刪除的向量、數據框或數組排序

> x <- c(3:5, 11:8, 8 + 0:5)
> x
 [1]  3  4  5 11 10  9  8  8  9 10 11 12 13
> unique(x)
[1]  3  4  5 11 10  9  8 12 13
> unique(x, fromLast = TRUE)
[1]  3  4  5  8  9 10 11 12 13    #排序後的索引

> a
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    1    2    4
[3,]    1    3    5
[4,]    1    2    3ast

> unique(a)
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    1    2    4
[3,]    1    3    5   #去除重複的最後一行數據

 

duplicated主要是斷定向量或數據框中的元素是否重複,它返回一個元素(行)是否是重複的邏輯向量filter

> duplicated(a)
[1] FALSE FALSE FALSE  TRUE    # 返回一個是否重複的邏輯判斷語言

> a[!duplicated(a),]
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    1    2    4
[3,]    1    3    5                         #去除重複的最後一行data

 

若是把第二列有重複的去除,則須要加一個索引去重

> index <- duplicated(a[,2])
> index
[1] FALSE  TRUE FALSE  TRUE
> a[!index,]
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    1    3    5       index

相關文章
相關標籤/搜索