AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79435770
Accepted
Swawa
Swawa
Asked: 2025-02-13 18:05:32 +0800 CST2025-02-13 18:05:32 +0800 CST 2025-02-13 18:05:32 +0800 CST

Crie JSON a partir de CSV e adicione algumas linhas de cabeçalho com Pandas

  • 772

Encontrei esta postagem que inicialmente parecia ser exatamente o que eu estava procurando, mas não me ajudou: Adicionando cabeçalho e rodapé à saída JSON do Python

Tenho um arquivo csv que leio como Pandas dataframe:

import os
import csv
import json
import pandas as pd
csvFilePath = "Mypath"
track = pd.read_csv(csvFilePath, header = 0, skiprows = 0, delimiter = ";")

O exemplo csv se parece com isto:

Param1;Param2;name;lat;lon;altitude;vert_rate;track;speed;category;Param3;Param4;Param5
999999;9999;rocket;57.878696;11.160667;1089;0;137;2;99;999;16;0
999999;9999;rocket;57.878796;11.160668;2543.963336;152638.0483;137;2;99;999;15;0
999999;9999;rocket;57.878896;11.160670;4226.050004;126781.7063;137;2;99;999;14;0
999999;9999;rocket;57.878796;11.160669;6091.207544;121824.349;137;2;99;999;13;0
999999;9999;rocket;57.878696;11.160667;8098.097372;121471.6581;137;2;99;999;12;0

Agora eu gostaria de proteger esse dataframe com um cabeçalho adicional como um arquivo JSON: O cabeçalho adicional se parece com este dicionário:

headlines={
           "now": 1636008051.9,
           "messages": 6236,
           }

O JSON de destino deve conter as informações fornecidas por "headlines" (mas sem seu nome) e o conteúdo do dataframe:

{
  "now": 1636008051.9,
  "messages": 6236,
  "track": [
    {      
      "Param1": 999999,
      "Param2": "9999",
      "name": "rocket",
      "lat":  57.878696,
      "lon": 11.160667,
      "altitude": 1089,
      "vert_rate": 0,
      "track": 137,
      "speed": 2,
      "category": 99,
      "Param3": 999,
      "Param4": 16,
      "Param5": 0
    }
    {      
      "Param1": 999999,
      "Param2": "9999",
      "name": "rocket",
      "lat":  57.878796,
      "lon": 11.160668,
      "altitude": 2543.963336,
      "vert_rate": 152638.0483,
      "track": 137,
      "speed": 2,
      "category": 99,
      "Param3": 999,
      "Param4": 15,
      "Param5": 0
    }
    {      
      "Param1": 999999,
      "Param2": "9999",
      "name": "rocket",
      "lat":  57.878896,
      "lon": 11.160670,
      "altitude": 4226.050004,
      "vert_rate": 126781.7063,
      "track": 137,
      "speed": 2,
      "category": 99,
      "Param3": 999,
      "Param4": 14,
      "Param5": 0
    }
    {...and so on...}
  ]
}

O próprio dataframe eu posso simplesmente transformar em JSON assim:

json = track.to_json(path_out + "result.json", orient='records')

mas aqui não sei como adicionar as linhas precedentes do dict "header" Como posso juntar o dicionário e o csv para gerar o JSON? Ou há uma maneira mais simples? Ou alguma dica para uma postagem que não encontrei? Preciso fazer isso no pandas, pois o csv-dataframe será necessário posteriormente.

python
  • 1 1 respostas
  • 37 Views

1 respostas

  • Voted
  1. Best Answer
    mozway
    2025-02-13T18:09:22+08:002025-02-13T18:09:22+08:00

    Crie um dicionário, atribua-o como uma nova chave de dicionário e exporte com json.dump:

    import json
    
    headlines['track'] = df.to_dict(orient='records')
    
    with open(path_out + 'result.json', 'w') as f:
        json.dump(headlines, f)
    

    Ou como uma string:

    import json
    
    headlines['track'] = df.to_dict(orient='records')
    
    print(json.dumps(headlines, indent=2))
    

    Saída:

    {
      "now": 1636008051.9,
      "messages": 6236,
      "track": [
        {
          "Param1": 999999,
          "Param2": 9999,
          "name": "rocket",
          "lat": 57.878696,
          "lon": 11.160667,
          "altitude": 1089.0,
          "vert_rate": 0.0,
          "track": 137,
          "speed": 2,
          "category": 99,
          "Param3": 999,
          "Param4": 16,
          "Param5": 0
        },
        {
          "Param1": 999999,
          "Param2": 9999,
          "name": "rocket",
          "lat": 57.878796,
          "lon": 11.160668,
          "altitude": 2543.963336,
          "vert_rate": 152638.0483,
          "track": 137,
          "speed": 2,
          "category": 99,
          "Param3": 999,
          "Param4": 15,
          "Param5": 0
        },
        {
          "Param1": 999999,
          "Param2": 9999,
          "name": "rocket",
          "lat": 57.878896,
          "lon": 11.16067,
          "altitude": 4226.050004,
          "vert_rate": 126781.7063,
          "track": 137,
          "speed": 2,
          "category": 99,
          "Param3": 999,
          "Param4": 14,
          "Param5": 0
        },
        {
          "Param1": 999999,
          "Param2": 9999,
          "name": "rocket",
          "lat": 57.878796,
          "lon": 11.160669,
          "altitude": 6091.207544,
          "vert_rate": 121824.349,
          "track": 137,
          "speed": 2,
          "category": 99,
          "Param3": 999,
          "Param4": 13,
          "Param5": 0
        },
        {
          "Param1": 999999,
          "Param2": 9999,
          "name": "rocket",
          "lat": 57.878696,
          "lon": 11.160667,
          "altitude": 8098.097372,
          "vert_rate": 121471.6581,
          "track": 137,
          "speed": 2,
          "category": 99,
          "Param3": 999,
          "Param4": 12,
          "Param5": 0
        }
      ]
    }
    
    • 2

relate perguntas

  • Como divido o loop for em 3 quadros de dados individuais?

  • Como verificar se todas as colunas flutuantes em um Pandas DataFrame são aproximadamente iguais ou próximas

  • Como funciona o "load_dataset", já que não está detectando arquivos de exemplo?

  • Por que a comparação de string pandas.eval() retorna False

  • Python tkinter/ ttkboostrap dateentry não funciona quando no estado somente leitura

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve