Introdução a DataFrames

Manipulação de dados com o pandas

Richie Cotton

Data Evangelist at DataCamp

Qual é o objetivo dos pandas?

Manipulação de dados com o pandas

Descrição do curso

  • Capítulo 1: DataFrames
    • Classificação e criação de subconjuntos
    • Criação de novas colunas
  • Capítulo 2: Agregação de dados
    • Estatísticas de resumo
    • Contagem
    • Estatísticas de resumo agrupadas
  • Capítulo 3: Fatiamento e indexação de dados

    • Criação de subconjuntos usando fatiamento
    • Índices e subconjuntos usando índices
  • Capítulo 4: Criação e visualização de dados

    • Geração de gráficos
    • Tratamento de dados faltantes
    • Leitura de dados em um DataFrame
Manipulação de dados com o pandas

O pandas foi desenvolvido com base no NumPy e no Matplotlib

Triângulo em cima de dois retângulos. O triângulo representa o pacote pandas, enquanto os retângulos representam os pacotes NumPy e Matplotlib.

Manipulação de dados com o pandas

O pandas é pop

Emoji de um panda, repetido centenas de vezes, representando muitos usuários do pandas.

1 https://pypistats.org/packages/pandas
Manipulação de dados com o pandas

Dados retangulares

Name Breed Color Height (cm) Weight (kg) Date of Birth
Bella Labrador Brown 56 25 2013-07-01
Charlie Poodle Black 43 23 2016-09-16
Lucy Chow Chow Brown 46 22 2014-08-25
Cooper Schnauzer Gray 49 17 2011-12-11
Max Labrador Black 59 29 2017-01-20
Stella Chihuahua Tan 18 2 2015-04-20
Bernie St. Bernard White 77 74 2018-02-27
Manipulação de dados com o pandas

DataFrames do pandas

print(dogs)
      name        breed  color  height_cm  weight_kg date_of_birth
0    Bella     Labrador  Brown         56         24    2013-07-01
1  Charlie       Poodle  Black         43         24    2016-09-16
2     Lucy    Chow Chow  Brown         46         24    2014-08-25
3   Cooper    Schnauzer   Gray         49         17    2011-12-11
4      Max     Labrador  Black         59         29    2017-01-20
5   Stella    Chihuahua    Tan         18          2    2015-04-20
6   Bernie  St. Bernard  White         77         74    2018-02-27
Manipulação de dados com o pandas

Como explorar um DataFrame: .head()

print(dogs.head())
      name        breed  color  height_cm  weight_kg date_of_birth
0    Bella     Labrador  Brown         56         24    2013-07-01
1  Charlie       Poodle  Black         43         24    2016-09-16
2     Lucy    Chow Chow  Brown         46         24    2014-08-25
3   Cooper    Schnauzer   Gray         49         17    2011-12-11
4      Max     Labrador  Black         59         29    2017-01-20
Manipulação de dados com o pandas

Como explorar um DataFrame: .info()

print(dogs.info())
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 7 entries, 0 to 6
Data columns (total 6 columns):
 #   Column         Non-Null Count  Dtype 
 --  ------         --------------  ----- 
 0   name           7 non-null      object
 1   breed          7 non-null      object
 2   color          7 non-null      object
 3   height_cm      7 non-null      int64 
 4   weight_kg      7 non-null      int64 
 5   date_of_birth  7 non-null      object
dtypes: int64(2), object(4)
memory usage: 464.0+ bytes
Manipulação de dados com o pandas

Como explorar um DataFrame: .shape

print(dogs.shape)
(7, 6)
Manipulação de dados com o pandas

Como explorar um DataFrame: .describe()

print(dogs.describe())
       height_cm  weight_kg
count   7.000000   7.000000
mean   49.714286  27.428571
std    17.960274  22.292429
min    18.000000   2.000000
25%    44.500000  19.500000
50%    49.000000  23.000000
75%    57.500000  27.000000
max    77.000000  74.000000
Manipulação de dados com o pandas

Componentes de um DataFrame: .values

print(dogs.values)
array([['Bella', 'Labrador', 'Brown', 56, 24, '2013-07-01'],
       ['Charlie', 'Poodle', 'Black', 43, 24, '2016-09-16'],
       ['Lucy', 'Chow Chow', 'Brown', 46, 24, '2014-08-25'],
       ['Cooper', 'Schnauzer', 'Gray', 49, 17, '2011-12-11'],
       ['Max', 'Labrador', 'Black', 59, 29, '2017-01-20'],
       ['Stella', 'Chihuahua', 'Tan', 18, 2, '2015-04-20'],
       ['Bernie', 'St. Bernard', 'White', 77, 74, '2018-02-27']],
      dtype=object)
Manipulação de dados com o pandas

Componentes de um DataFrame: .columns e .index

print(dogs.columns)
Index(['name', 'breed', 'color', 'height_cm', 'weight_kg', 'date_of_birth'],
dtype='object')
dogs.index
RangeIndex(start=0, stop=7, step=1)
Manipulação de dados com o pandas

Filosofia do pandas

Deve haver uma – e de preferência apenas uma – maneira óbvia de fazer algo.

     - The Zen of Python deTim Peters, Item 13

Canivete suíço verde

1 https://www.python.org/dev/peps/pep-0020/
Manipulação de dados com o pandas

Vamos praticar!

Manipulação de dados com o pandas

Preparing Video For Download...