Olá! Boas-vindas a este curso de Pandas. Meu nome é Mirla Borges e sou instrutora da Alura.
Autodescrição: Mirla é uma mulher branca, de cabelos cacheados, pretos, na altura do ombro. Tem o rosto fino e alongado, olhos e sobrancelhas pretas. Nos olhos, um óculos de grau com armação redonda. No corpo, uma camiseta preta. Ao fundo, há uma parede lisa com iluminação verde.
Este curso é destinado a pessoas que querem entender as ferramentas do Pandas para o tratamento e manipulação de diversos tipos de dados.
Nele, vamos trabalhar com um projeto focado em precificação inteligente no âmbito de hospedagem de imóveis. Para isso, teremos uma variedade de dados que buscaremos entender.
Trataremos e manipularemos dados que interferem no produto final:
Faremos tudo isso utilizando o Google Colab.
Com este curso, seremos capazes de:
Para que haja maior aproveitamento deste curso, recomendamos um conhecimento prévio dos elementos abaixo:
Vamos lá!
A área de dados possui muitas aplicações, em diversos tipos de negócio — entre eles, o turismo.
Como exemplo, podemos aplicá-la na precificação do aluguel de imóveis a curto prazo.
Neste curso, faremos uma preparação de dados. Isso significa que não faremos uma análise deles, mas sim a sua transformação e manipulação, para que atinjam um objetivo — neste caso, a solução do nosso problema.
Nossa aplicação visa realizar um estudo dos nossos dados, com o objetivo de criar uma solução com precificação inteligente.
Trata-se de um algoritmo capaz de analisar as características de um imóvel — como comodidade, tamanho, ocupação do espaço em determinado período — e sugerir à pessoa anfitriã um preço a ser cobrado por diárias que garanta o lucro em momentos de alta demanda.
O problema está na estrutura dos nossos dados. Vamos conhecê-los e analisá-los.
Para conhecer os nossos dados, utilizaremos o Google Colab. Ele deve estar vazio e conectado.
Vamos retirar as opções da barra de ferramentas superior, acessando-a e clicando no botão "Alternar a visibilidade do cabeçalho", no canto superior direito.
Vamos importar os dados. Para isso, acessaremos a barra de ferramentas lateral, à esquerda da tela, onde clicaremos no botão "Arquivos".
Com isso, será aberta uma barra secundária à direita, onde veremos o conteúdo da pasta "Arquivos".
Nela, clicaremos no botão "Fazer upload para o armazenamento da sessão" que abrirá uma janela com o explorador do nosso computador. Neste, por sua vez, buscaremos as bases de dados abaixo, que já deverão ter sido baixadas.
dados_hospedagem.json
moveis_disponiveis.json
Observação: O link para download das bases de dados estão disponíveis nas atividades desta aula.
Clicaremos no arquivo dados_hospedagem.json
e no botão "Abrir". Com isso, realizaremos o upload dos primeiros dados a serem trabalhados em nosso Notebook do Google Colab.
Vamos esperar o arquivo ser carregado. Quando este processo terminar, veremos na barra secundária lateral o nome do nosso arquivo.
Para conhecer os dados, utilizaremos a biblioteca Pandas. Para isso, na primeira linha de código, adicionaremos o import pandas
.
Além disso, incluiremos o comando as pd
para podermos utilizar o pd
quando chamarmos esta biblioteca. Por fim, pressionaremos "Shift+Enter", o que descerá o cursor para a linha 2.
Vamos ler o arquivo que importamos. Para isso, precisaremos do método read_json()
, já que nosso arquivo é do tipo JSON.
Na linha atual, atribuiremos um novo dataframe, chamado dados
. Ele receberá os dados de hospedagem por meio do pd.read_json()
.
dados = pd.read_json()
Entre os parênteses do método, adicionaremos o caminho até o arquivo que importamos. Para coletá-lo, voltaremos à barra secundária à direita, onde o buscaremos e clicaremos no botão à sua direita, que possui um ícone de três pontos.
Será aberta uma lista suspensa, onde selecionaremos a opção "copiar caminho". Com isso, teremos o caminho do arquivo vinculado à nossa área de transferência.
Voltando à linha 2, entre os parênteses do read_json()
, abriremos e fecharemos aspas simples, para criar uma string. Entre elas, pressionaremos "Ctrl+V", o que colará todo o caminho para a leitura do arquivo JSON.
dados = pd.read_json('/content/dados_hospedagem.json')
Pressionaremos "Ctrl+Enter" para descer de linha e rodaremos o dados.head()
para conseguir visualizar as primeiras cinco linhas do nosso arquivo.
dados = pd.read_json('/content/dados_hospedagem.json')
dados.head()
Pressionaremos "Shift+Enter" e veremos o resultado abaixo:
index | info_moveis |
---|---|
0 | {'avaliacao_geral': '10.0', 'experiencia_local... |
1 | {'avaliacao_geral': '10.0', 'experiencia_local... |
2 | {'avaliacao_geral': '10.0', 'experiencia_local... |
3 | {'avaliacao_geral': '10.0', 'experiencia_local... |
4 | {'avaliacao_geral': '10.0', 'experiencia_local... |
Temos uma visualização de como é o nosso arquivo, na qual percebemos que os dados estão aninhados em formato de dicionário. Isso dificulta o entendimento.
Por exemplo, observaremos que a linha 0 é um dicionário que possui a chave avaliacao_geral
, o valor 10.0
e outra chave com o nome exibido parcialmente (experiencia_local...
).
No próximo vídeo, precisamos desaninhar os dados para conseguir observar melhor os valores e os resultados que temos neste dataframe.
Continuaremos a leitura e o desbravamento dos nossos dados.
Anteriormente, descobrimos que eles estão aninhados em dicionários. Para estudá-los e identificar onde podemos prepará-los, tratá-los e transformá-los, precisamos que estejam destrinchados.
Vamos fechar a aba secundária "Arquivos", à direita, para termos uma visualização ampla do nosso código.
Na primeira célula disponível abaixo do último retorno, utilizaremos o método json_normalize()
que fará exatamente o que precisamos: a normalização desses dados — neste caso, da coluna info_moveis
.
Reatribuiremos os dados do dataframe para que o novo dataframe seja normalizado. Para isso, rodaremos o comando dados = pd.json_normalize()
. Dentro dos parênteses, adicionaremos como parâmetro um dados
, junto a um bloco de colchetes. Este receberá em seu interior, entre aspas simples, a coluna a ser normalizada: info_moveis
.
No final desta linha, fora do json_normalize()
, pressionaremos "Enter" para descer de linha. Nesta, pediremos uma observação dos nossos dados normalizados, digitando dados
.
dados = pd.json_normalize(dados['info_moveis'])
dados
Pressionando "Shift+Enter", veremos um retorno de 70 linhas, dentre as quais exibimos abaixo algumas linhas como exemplo:
index | avaliacao_geral | experiencia_local | max_hospedes | descricao_local | descricao_vizinhanca | quantidade_banheiros | quantidade_quartos | quantidade_camas | modelo_cama | comodidades | taxa_deposito | taxa_limpeza | preco |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 10.0 | -- | 1 | [This clean and comfortable one bedroom sits r... | [Lower Queen Anne is near the Seattle Center (... | [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ... | [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ... | [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ... | [Real Bed, Futon, Futon, Pull-out Sofa, Real B... | [{Internet,"Wireless Internet",Kitchen,"Free P... | [$0, $0, $0, $0, $0, $350.00, $350.00, $350.00... | [$0, $0, $0, $20.00, $15.00, $28.00, $35.00, $... | [$110.00, $45.00, $55.00, $52.00, $85.00, $50.... |
1 | 10.0 | -- | 10 | [Welcome to the heart of the 'Ballard Brewery ... | [--, Capital Hill is the heart of Seattle, bor... | [2, 3, 2, 3, 3, 3, 2, 1, 2, 2, 2] | [3, 4, 2, 3, 3, 3, 3, 3, 3, 4, 3] | [5, 6, 8, 3, 3, 5, 4, 5, 6, 7, 4] | [Real Bed, Real Bed, Real Bed, Real Bed, Real ... | [{TV,Internet,"Wireless Internet",Kitchen,"Fre... | [$500.00, $300.00, $0, $300.00, $300.00, $360.... | [$125.00, $100.00, $85.00, $110.00, $110.00, $... | [$350.00, $300.00, $425.00, $300.00, $285.00, ... |
2 | 10.0 | -- | 11 | [New modern house built in 2013. Spectacular ... | [Upper Queen Anne is a charming neighborhood f... | [4] | [5] | [7] | [Real Bed] | [{TV,"Cable TV",Internet,"Wireless Internet","... | [$1,000.00] | [$300.00] | [$975.00] |
3 | 10.0 | -- | 12 | [Our NW style home is 3200+ sq ft with 3 level... | [The Views from our top floor! Wallingford ha... | [3, 3, 3, 3, 3, 3, 3, 3] | [6, 6, 5, 5, 5, 5, 4, 4] | [6, 6, 7, 8, 7, 7, 6, 6] | [Real Bed, Real Bed, Real Bed, Real Bed, Real ... | [{Internet,"Wireless Internet",Kitchen,"Free P... | [$500.00, $500.00, $500.00, $500.00, $500.00, ... | [$225.00, $300.00, $250.00, $250.00, $250.00, ... | [$490.00, $550.00, $350.00, $350.00, $350.00, ... |
4 | 10.0 | -- | 14 | [Perfect for groups. 2 bedrooms, full bathroom... | [Safeway grocery store within walking distance... | [2, 3] | [2, 6] | [3, 9] | [Real Bed, Real Bed] | [{TV,Internet,"Wireless Internet",Kitchen,"Fre... | [$300.00, $2,000.00] | [$40.00, $150.00] | [$200.00, $545.00] |
... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... |
Nele, vemos dados numéricos, de texto e também listas com os dois tipos.
Para realizar o tratamento focado em cada tipo de dado, precisaremos realizar um desagrupamento, removendo-os das listas. Faremos isso a seguir.
O curso Pandas: transformação e manipulação de dados possui 86 minutos de vídeos, em um total de 39 atividades. Gostou? Conheça nossos outros cursos de Data Science em Data Science, ou leia nossos artigos de Data Science.
Matricule-se e comece a estudar com a gente hoje! Conheça outros tópicos abordados durante o curso:
Impulsione a sua carreira com os melhores cursos e faça parte da maior comunidade tech.
1 ano de Alura
Assine o PLUS e garanta:
Formações com mais de 1500 cursos atualizados e novos lançamentos semanais, em Programação, Inteligência Artificial, Front-end, UX & Design, Data Science, Mobile, DevOps e Inovação & Gestão.
A cada curso ou formação concluído, um novo certificado para turbinar seu currículo e LinkedIn.
No Discord, você tem acesso a eventos exclusivos, grupos de estudos e mentorias com especialistas de diferentes áreas.
Faça parte da maior comunidade Dev do país e crie conexões com mais de 120 mil pessoas no Discord.
Acesso ilimitado ao catálogo de Imersões da Alura para praticar conhecimentos em diferentes áreas.
Explore um universo de possibilidades na palma da sua mão. Baixe as aulas para assistir offline, onde e quando quiser.
Acelere o seu aprendizado com a IA da Alura e prepare-se para o mercado internacional.
1 ano de Alura
Todos os benefícios do PLUS e mais vantagens exclusivas:
Luri é nossa inteligência artificial que tira dúvidas, dá exemplos práticos, corrige exercícios e ajuda a mergulhar ainda mais durante as aulas. Você pode conversar com a Luri até 100 mensagens por semana.
Aprenda um novo idioma e expanda seus horizontes profissionais. Cursos de Inglês, Espanhol e Inglês para Devs, 100% focado em tecnologia.
Transforme a sua jornada com benefícios exclusivos e evolua ainda mais na sua carreira.
1 ano de Alura
Todos os benefícios do PRO e mais vantagens exclusivas:
Mensagens ilimitadas para estudar com a Luri, a IA da Alura, disponível 24hs para tirar suas dúvidas, dar exemplos práticos, corrigir exercícios e impulsionar seus estudos.
Envie imagens para a Luri e ela te ajuda a solucionar problemas, identificar erros, esclarecer gráficos, analisar design e muito mais.
Escolha os ebooks da Casa do Código, a editora da Alura, que apoiarão a sua jornada de aprendizado para sempre.