DEV Community

Francisco Júnior
Francisco Júnior

Posted on

NumPy e pandas: Ferramentas Essenciais para Análise de Dados

A análise de dados é uma parte fundamental do processo de tomada de decisões em diversos campos, desde a pesquisa científica até os negócios. Para facilitar essa análise, foram desenvolvidas várias bibliotecas em Python, das quais duas se destacam: NumPy e pandas. NumPy é uma biblioteca que fornece suporte para arrays multidimensionais e funções matemáticas de alto desempenho, enquanto pandas é uma biblioteca que oferece estruturas de dados e funções para manipulação de dados tabulares. Neste artigo, exploraremos como essas duas bibliotecas podem ser usadas de maneira eficaz para análise de dados.

NumPy: Fundamentação Matemática

NumPy é a pedra angular de muitas bibliotecas de análise de dados em Python devido à sua capacidade de lidar com arrays multidimensionais. Ele fornece um ambiente eficiente para realizar operações matemáticas em dados. Abaixo estão alguns dos principais recursos do NumPy:

1. Arrays NumPy

O objeto fundamental no NumPy é o ndarray (array multidimensional), que permite armazenar e manipular dados de maneira eficiente. Esses arrays são homogêneos, ou seja, todos os elementos devem ter o mesmo tipo de dados.

import numpy as np

# Criando um array NumPy
arr = np.array([1, 2, 3, 4, 5])
Enter fullscreen mode Exit fullscreen mode

2. Operações Matemáticas

NumPy oferece uma ampla gama de funções matemáticas que podem ser aplicadas diretamente aos arrays, sem a necessidade de loops explícitos.

# Operações com arrays NumPy
arr = np.array([1, 2, 3])
result = arr + 2
Enter fullscreen mode Exit fullscreen mode

3. Indexação e Fatiamento

Você pode acessar elementos específicos em um array NumPy e também realizar operações de fatiamento para obter partes do array.

# Indexação e fatiamento
arr = np.array([1, 2, 3, 4, 5])
element = arr[2]  # Acessa o terceiro elemento (índice 2)
subset = arr[1:4]  # Fatiamento: obtém elementos de índice 1 a 3
Enter fullscreen mode Exit fullscreen mode

4. Funções Estatísticas

NumPy inclui funções estatísticas úteis, como média, desvio padrão e mediana.

# Funções estatísticas
data = np.array([10, 20, 30, 40, 50])
mean = np.mean(data)
std_dev = np.std(data)
median = np.median(data)
Enter fullscreen mode Exit fullscreen mode

pandas: Manipulação de Dados Tabulares

Enquanto NumPy é excelente para operações matemáticas em arrays, pandas é projetado para trabalhar com dados tabulares, como planilhas e bancos de dados relacionais. Aqui estão os principais recursos do pandas:

1. DataFrame

O objeto central do pandas é o DataFrame, que é uma estrutura de dados bidimensional semelhante a uma tabela de banco de dados. Ela permite a organização de dados em linhas e colunas.

import pandas as pd

# Criando um DataFrame
data = {'Nome': ['Alice', 'Bob', 'Carol'],
        'Idade': [25, 30, 35]}
df = pd.DataFrame(data)
Enter fullscreen mode Exit fullscreen mode

2. Leitura e Escrita de Dados

O pandas oferece funções para importar e exportar dados de várias fontes, como CSV, Excel e bancos de dados.

# Leitura e escrita de dados
df = pd.read_csv('dados.csv')
df.to_excel('dados.xlsx')
Enter fullscreen mode Exit fullscreen mode

3. Indexação e Seleção

Você pode selecionar e filtrar dados em um DataFrame com base em condições específicas.

# Indexação e seleção
subset = df[df['Idade'] > 30]
row = df.loc[0]  # Acessa a primeira linha
Enter fullscreen mode Exit fullscreen mode

4. Agregação e Transformação

pandas permite realizar operações de agregação, como soma, média, contagem, e também transformações de dados, como pivoteamento e derivação de novas colunas.

# Agregação e transformação
mean_age = df['Idade'].mean()
pivot_table = df.pivot_table(index='Nome', values='Idade', aggfunc='mean')
Enter fullscreen mode Exit fullscreen mode

NumPy e pandas em Conjunto

NumPy e pandas são frequentemente usados em conjunto para realizar análises de dados completas. Você pode converter DataFrames em arrays NumPy para executar cálculos matemáticos ou usar funções de NumPy para manipular os dados em DataFrames.

import numpy as np
import pandas as pd

# Convertendo DataFrame para array NumPy
df = pd.DataFrame({'A': [1, 2, 3], 'B': [4, 5, 6]})
numpy_array = df.to_numpy()
Enter fullscreen mode Exit fullscreen mode

Conclusão

NumPy e pandas são ferramentas essenciais para análise de dados em Python. Enquanto NumPy é ideal para operações matemáticas em arrays, pandas se destaca na manipulação de dados tabulares. Usadas em conjunto, essas bibliotecas oferecem uma poderosa plataforma para explorar e entender os dados, prepará-los para análise estatística e visualização. Se você está envolvido em análise de dados, aprender a usar NumPy e pandas é um passo importante para se tornar um profissional eficiente e eficaz na análise de dados.

Top comments (0)