Olá! Me chamo Mirla Costa, e sou instrutora da Alura.
Audiodescrição: Mirla se descreve como uma mulher de pele clara, com cabelos cacheados e pretos, que caem abaixo da altura dos ombros. Ela usa óculos de grau com armação redonda e veste uma camisa preta lisa. Ao fundo, duas prateleiras flutuantes com livros e decorações são visíveis.
Neste vídeo, iremos relembrar como normalizar arquivos JSON para transformá-los em dataframes, de forma que possam ser manipulados em projetos de data science.
Um notebook com todo o material que será apresentado, incluindo alguns dados, está disponível para que você possa acessar todo o conteúdo exibido.
Iniciaremos com o notebook. Ao nos referirmos a arquivos JSON, falamos de um formato que armazena dados em pares de chaves e valores, em um formato de dicionário, como já conhecemos no Python. Para exemplificar, temos o arquivo_1.json
salvo na seção de "Arquivos" do Google Colab.
Vamos abri-lo para observar que todos os valores de colunas e elementos dessas colunas estão organizados em dicionários e grupos de pares chave-valor:
[
{
"id_vendedor": 101,
"id_cliente": 1001,
"produto": "Notebook",
"quantidade": 1,
"valor_unitario": 3500.00,
"valor_total": 3500.00
},
{
"id_vendedor": 102,
"id_cliente": 1002,
"produto": "Smartphone",
"quantidade": 2,
"valor_unitario": 1200.00,
"valor_total": 2400.00
},
{
"id_vendedor": 103,
"id_cliente": 1003,
"produto": "Monitor",
"quantidade": 3,
"valor_unitario": 800.00,
"valor_total": 2400.00
}
]
Para importar esse arquivo e transformá-lo em um dataframe manipulável, utilizamos a biblioteca Pandas. Em uma célula do Google Colab, digitamos:
import pandas as pd
Para ler o arquivo e convertê-lo em um dataframe, usamos a função pd.read_json()
, fornecendo o caminho do arquivo.
df = pd.read_json('arquivo_1.json')
df
- id_vendedor id_cliente produto quantidade valor_unitario valor_total 0 101 1001 Notebook 1 3500 3500 1 102 1002 Smartphone 2 1200 2400 2 103 1003 Monitor 3 800 2400
Ao executar, o resultado será o dataframe que pode ser trabalhado em projetos.
Contudo, esse não é o único tipo de arquivo JSON possível. Também existem arquivos com dicionários aninhados, como o arquivo_2.json
.
[
{
"id_vendedor": 101,
"id_cliente": 1001,
"detalhes_compra": {
"produto": "Notebook",
"quantidade": 1,
"valor_unitario": 3500.00,
"valor_total": 3500.00
}
},
{
"id_vendedor": 102,
"id_cliente": 1002,
"detalhes_compra": {
"produto": "Smartphone",
"quantidade": 2,
"valor_unitario": 1200.00,
"valor_total": 2400.00
}
},
{
"id_vendedor": 103,
"id_cliente": 1003,
"detalhes_compra": {
"produto": "Monitor",
"quantidade": 3,
"valor_unitario": 800.00,
"valor_total": 2400.00
}
}
]
Ao abrir esse arquivo, observamos que ele contém um dicionário dentro de outros dicionários, que por sua vez estão em uma lista de dicionários.
Nesse caso, teremos dificuldades em utilizar o pd.read_json()
. Ao utilizarmos novamente o pd.read_json()
com o arquivo_2.json
e executarmos a célula, observamos que o dicionário aninhado no segundo nível se apresenta de forma incorreta, o que impede o acesso aos dados.
df = pd.read_json('arquivo_2.json')
df
- id_vendedor id_cliente detalhes_compra 0 101 1001 {'produto': 'Notebook', 'quantidade': 1, 'valor_unitario': 3500, 'valor_total': 3500} 1 102 1002 {'produto': 'Smartphone', 'quantidade': 2, 'valor_unitario': 1200, 'valor_total': 2400} 2 103 1003 {'produto': 'Monitor', 'quantidade': 3, 'valor_unitario': 800, 'valor_total': 2400}
Isso ocorre porque o read_json()
só lê arquivos JSON com dicionários em um único nível. Quando estão aninhados, ele não consegue ler.
pd.json_normalize
É necessário normalizar nossos arquivos JSON. A normalização é realizada com a função pd.json_normalize
, do Pandas. Para aplicá-la, não utilizaremos o dataframe recém-criado, pois o json_normalize
requer uma lista de dicionários ou um dicionário para aplicar a normalização. Portanto, ao invés de manipular o dataframe, leremos o arquivo_2.json
e obter esses dados como uma lista de dicionários.
Para isso, utilizaremos a biblioteca JSON, que é nativa do Python. Faremos o import dessa biblioteca em uma nova célula:
import json
Em uma nova célula, leremos o arquivo_2.json
no formato de leitura, especificando 'r'
dentro da estrutura with
. Armazenaremos o conteúdo em dados usando o comando json.load()
.
with open('arquivo_2.json', 'r') as arquivo:
dados = json.load(arquivo)
dados
[{'id_vendedor': 101,
'id_cliente': 1001,
'detalhes_compra': {'produto': 'Notebook',
'quantidade': 1,
'valor_unitario': 3500.0,
'valor_total': 3500.0}},
{'id_vendedor': 102,
'id_cliente': 1002,
'detalhes_compra': {'produto': 'Smartphone',
'quantidade': 2,
'valor_unitario': 1200.0,
'valor_total': 2400.0}},
{'id_vendedor': 103,
'id_cliente': 1003,
'detalhes_compra': {'produto': 'Monitor',
'quantidade': 3,
'valor_unitario': 800.0,
'valor_total': 2400.0}}]
Dessa forma, dados será uma lista de dicionários.
Para normalizar, basta encaminharmos esses dados para a função pd.json_normalize(dados)
, resultando em um dataframe totalmente manipulável.
df = pd.json_normalize(dados)
df
- id_vendedor id_cliente detalhes_compra.produto detalhes_compra.quantidade detalhes_compra.valor_unitario detalhes_compra.valor_total 0 101 1001 Notebook 1 3500.0 3500.0 1 102 1002 Smartphone 2 1200.0 2400.0 2 103 1003 Monitor 3 800.0 2400.0
Observamos que existe um separador dentro da coluna onde estavam os dados aninhados, o qual pode ser alterado posteriormente.
Para saber como modificar esse separador, é necessário consultar o material.
Um último detalhe refere-se ao comportamento da função json_normalize
quando recebe uma estrutura que não é exatamente um dicionário, como uma nova lista de dicionários. Em uma nova célula, inserimos:
dados = [
{
"id_vendedor": 101,
"id_cliente": 1001,
"compras": [
{"produto": "Notebook", "quantidade": 1, "valor_unitario": 3500.00, "valor_total": 3500.00},
{"produto": "Mouse", "quantidade": 2, "valor_unitario": 50.00, "valor_total": 100.00}
]
},
{
"id_vendedor": 102,
"id_cliente": 1002,
"compras": [
{"produto": "Smartphone", "quantidade": 1, "valor_unitario": 1200.00, "valor_total": 1200.00},
{"produto": "Fone de Ouvido", "quantidade": 1, "valor_unitario": 200.00, "valor_total": 200.00}
]
}
]
A chave "compras" contém uma lista de dicionários com novos dados. Ao executarmos a célula acima e aplicarmos o json_normalize
, percebemos que ele não consegue normalizar dicionários dentro de uma nova lista de dicionários, pois ele não expande a normalização quando encontra estruturas diferentes de dicionários, como listas, strings, valores, entre outros.
df = pd.json_normalize(dados)
df
- id_vendedor id_cliente compras 0 101 1001 [{'produto': 'Notebook', 'quantidade': 1, 'valor_unitario': 3500.0, 'valor_total': 3500.0}] 1 102 1002 [{'produto': 'Smartphone', 'quantidade': 1, 'valor_unitario': 1200.0, 'valor_total': 1200.0}]
Nesse caso, precisamos definir a chave para a normalização, utilizando o parâmetro record_path
. Ao utilizar a função json_normalize
, enviamos os dados e acrescentamos o parâmetro record_path
, indicando a chave que contém a nova lista, no caso, 'compras'
. Em uma nova célula, digitamos:
df = pd.json_normalize(dados, record_path='compras')
df
- produto quantidade valor_unitario valor_total 0 Notebook 1 3500.0 3500.0 1 Mouse 2 50.0 100.0 2 Smartphone 1 1200.0 1200.0 3 Fone de Ouvido 1 200.0 200.0
Ao executar a célula, observamos que a normalização da coluna "compras" foi realizada, mas as colunas "id_vendedor" e "id_cliente" foram perdidas. Para adicioná-las ao dataframe, utilizamos o parâmetro meta
, especificando as chaves id_vendedor
e id_cliente
junto à função json_normalize
.
df = pd.json_normalize(dados, record_path='compras', meta = ['id_vendedor', 'id_cliente'])
df
- produto quantidade valor_unitario valor_total id_vendedor id_cliente 0 Notebook 1 3500.0 3500.0 101 1001 1 Mouse 2 50.0 100.0 101 1001 2 Smartphone 1 1200.0 1200.0 102 1002 3 Fone de Ouvido 1 200.0 200.0 102 1002
Ao executar a célula, obtemos o dataframe totalmente normalizado e manipulável.
Esse é o processo necessário para aplicar a normalização de JSON e construir dataframes para uso em projetos de data science. Agora, estamos prontos para avançar para os exercícios e praticar o que foi aprendido.
Desejamos boas práticas! Até logo!
O curso Python: normalizando arquivos JSON possui 8 minutos de vídeos, em um total de 13 atividades. Gostou? Conheça nossos outros cursos de Excel 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.