Python np.unique() 함수에 대한 자세한 설명

np.unique()세부 기능: 배열의 고유 값 반환고유한 값은 기본적으로 작은 것부터 큰 것까지 정렬됩니다.
여기에 이미지 설명 삽입

몇 가지 중요한 매개변수
여기에 이미지 설명 삽입

return_index : 부울, 선택 사항. True로 설정하면 배열에서 고유한 값의 인덱스 번호를 반환하고 그렇지 않으면 반환하지 않습니다.
참고: 반환된 배열은 입력 배열과 크기가 다르며 고유한 값에 해당하는 인덱스만 포함합니다.

return_inverse : 부울, 선택 사항. True로 설정하면 고유 값별로 고유 값의 인덱스를 반환합니다[각 고유 값에 대해 인덱스는 동일].

참고: 반환된 배열은 입력 배열과 정확히 같은 크기입니다.

**return_count: 부울, 선택 사항. True로 설정하면 고유 값에 따라 배열의 고유 값 수를 반환합니다 [각 고유 값에 대해 인덱스는 동일].

참고: 반환된 배열은 입력 배열과 정확히 같은 크기입니다.

# Case 1
np.unique([1, 1, 2, 2, 3, 3])
# 得到唯一值数组
array([1, 2, 3])
# 对于多维数组而言,如果不指定axis,那么将多维数组看作一维数组进行唯一值寻找
a = np.array([[1, 1], [2, 3]])
np.unique(a)
array([1, 2, 3])
# 多维数组,指定axis,将axis下的看作一个整体进行唯一值search
# 对于二维数组,axis=0既是寻找完全不同的行
# 对于二维数组,axis=1既是寻找完全不同的列
a = np.array([[1, 0, 0], [1, 0, 0], [2, 3, 4], [2, 3, 4], [1, 4, 6]])
np.unique(a, axis=0)
array([[1 0 0], [1 4 6], [2 3 4]])

# Case 2
a = np.array(['a', 'b', 'b', 'c', 'a'])
u, indices = np.unique(a, return_index=True)
u
# 返回唯一值
array(['a', 'b', 'c'], dtype='<U1')
indices
# 返回唯一值对应的index,由于array只有三个唯一值,因此只有三个index
array([0, 1, 3], dtype=int64)
# 利用唯一值index提取唯一值
a[indices]
array(['a', 'b', 'c'], dtype='<U1')

# Case 3
a = np.array([1, 2, 6, 4, 2, 3, 2])
u, indices = np.unique(a, return_inverse=True)
u
# 返回唯一值
array([1, 2, 3, 4, 6])
indices
# 返回唯一值在原数组的index
array([0, 1, 4, 3, 1, 2, 1], dtype=int64)
# 利用【唯一值在原数组的index】数组得到原数组
u[indices]
array([1, 2, 6, 4, 2, 3, 2])
# Case 3
a = np.array([1, 2, 6, 4, 2, 3, 2])
values, counts = np.unique(a, return_counts=True)
values
# 返回唯一值
array([1, 2, 3, 4, 6])
counts
# 返回每个唯一值的数目
array([1, 3, 1, 1, 1], dtype=int64)# 进行原数组的还原,原始数组的顺序不发生变化
np.repeat(values, counts)
array([1, 2, 2, 2, 3, 4, 6])

#  Case 4
# 返回tuple类型的数据
date_uniques = np.unique(date, return_index=True, return_inverse=True, return_counts=True)

학습 링크:

Je suppose que tu aimes

Origine blog.csdn.net/weixin_45913084/article/details/131737103
conseillé
Classement