Análise de Valores Únicos com df.unique() no Pandas

O método unique() é uma função essencial na biblioteca Pandas para Python que retorna os valores únicos de uma Series (coluna) em ordem de aparecimento. É extremamente útil para análise exploratória de dados, especialmente para variáveis categóricas.

O que é df.unique()?

O método unique() retorna um array NumPy com os valores únicos de uma Series (coluna) do Pandas. Os valores são retornados na ordem em que aparecem na Series, o que preserva a sequência original.

Características importantes:

  • Retorna apenas valores únicos, eliminando duplicatas
  • Preserva a ordem de aparecimento dos valores
  • Funciona apenas com Series (colunas individuais), não com DataFrames completos
  • Ignora valores NaN por padrão (dependendo da versão do Pandas)

Exemplo básico de uso:

Saída esperada do código acima:

Comparação com Funções Similares

unique() vs value_counts()

Enquanto unique() retorna apenas os valores únicos, value_counts() retorna tanto os valores únicos quanto suas contagens:

unique():

  • Retorna array com valores únicos
  • Preserva ordem de aparecimento
  • Não mostra frequências
  • Mais rápido para apenas obter valores distintos

value_counts():

  • Retorna Series com valores únicos e contagens
  • Ordenado por frequência (padrão)
  • Mostra contagem de cada valor
  • Mais informativo para análise estatística

Exemplo comparativo:

Em R, as funções equivalentes são unique() e table():

unique() vs nunique()

Enquanto unique() retorna os valores únicos, nunique() retorna apenas a contagem de valores únicos:

unique():

  • Retorna os valores únicos
  • Útil quando precisamos dos valores específicos
  • Permite iterar sobre os valores distintos

nunique():

  • Retorna apenas o número de valores únicos
  • Útil para estatísticas rápidas
  • Mais eficiente quando só precisamos da contagem

Exemplo comparativo:

Em R, podemos usar length(unique()) para obter o equivalente a nunique():

Aplicações Práticas do unique()

O método unique() é extremamente útil em diversas situações de análise de dados:

1. Análise de Variáveis Categóricas

Identificar todas as categorias presentes em uma variável:

2. Criação de Mapas de Valores

Usar os valores únicos para criar dicionários de mapeamento:

3. Filtragem de Dados

Usar valores únicos para filtrar o DataFrame:

Em R, aplicações similares com unique():

Quando Usar df.unique()

Análise Exploratória de Dados

Use unique() para entender rapidamente as categorias presentes em uma coluna.

Pré-processamento de Dados

Use unique() para identificar valores que precisam ser tratados antes da modelagem.

Criação de Variáveis Dummy

Use unique() para identificar todas as categorias necessárias para criar variáveis dummy.

Em R, uso similar para one-hot encoding:

Exemplo Prático Completo

Vamos explorar um exemplo prático de uso do unique() em um conjunto de dados mais complexo:

Em R, podemos realizar uma análise similar com:

⚠️ Considerações Importantes

Ao usar unique(), esteja ciente das seguintes considerações:

  • unique() não funciona diretamente em DataFrames completos, apenas em Series
  • Valores NaN são tratados de forma diferente dependendo da versão do Pandas
  • Para colunas com muitos valores únicos, o resultado pode ser muito grande
  • A ordem dos valores é preservada conforme aparecem nos dados, não em ordem alfabética/numerica
  • Para obter valores únicos ordenados, use sorted(df['coluna'].unique())

Conclusão

O método df.unique() é uma ferramenta simples mas poderosa para análise exploratória de dados em Pandas. Ele fornece uma maneira rápida de identificar valores distintos em uma coluna, sendo especialmente útil para variáveis categóricas.

Lembre-se de que unique() é mais eficiente quando você precisa dos valores específicos, enquanto value_counts() é melhor quando você precisa tanto dos valores quanto de suas frequências, e nunique() é mais adequado quando você precisa apenas da contagem de valores únicos.

Referências