【问题标题】:Python - Converting json data to a csv format for a specific keyPython - 将 json 数据转换为特定键的 csv 格式
【发布时间】:2019-05-21 14:31:10
【问题描述】:

我正在开发一个应用程序,并希望使用密钥从 json 文件中提取数据并将其存储到 csv 文件中以供进一步使用。

示例 json 数据如下所示:

[ {“姓名”:“约翰”,“办公室”:“第一大道”,“出生日期”:“1978-01-01”},{“姓名”:“简”,“办公室”:“ 2nd Ave","出生日期": "1970-01-01"}]

这只是虚拟数据

到目前为止,我所做的是:


with open("input.json") as infile, open('output.csv', 'w') as outfile:
    writer = csv.writer(outfile, delimiter=' ')

    i=0
    for line in infile:
        d = json.loads(line)
        writer.writerows(d[i]['Name'])
        i=i+1

但是使用这段代码,我面临的问题是 csv 文件看起来像:

J

o

h

n

这就是我想要的:

名字

约翰

知道为什么会发生这种情况以及如何解决吗?

还有:

我想在 csv 中添加一个标签作为 0 作为第二列。如:

姓名ID

约翰 0

简0

【问题讨论】:

  • 可能不相关,但输入文件中的键不均匀:您有“名称”(最后一个空格)和“名称”(没有最后一个空格)
  • 你提到它只是虚拟数据

标签: python json csv


【解决方案1】:

就我个人而言,我会直接使用pandas

import pandas as pd
df = pd.read_json('input.json')
df['Name'].to_csv('output.csv', index=False)
df['ID'] = O
df[['Name','ID']].to_csv('output_2.csv', index=False, sep = ' ')

据我了解,“ID”值始终等于 0。对吗?

【讨论】:

  • 是的 id 只是 csv 文件中所有条目都为 0 的另一列,但是通过此代码,它被添加到同一列而不是新列?
  • 在代码中我定义了一个新列并将值设置为 0。然后我获取数据集的一个子集('Name'、'ID')并将其导出到所需的 csv 文件
【解决方案2】:

对于每一行,您的“姓名”不是一个列表。

line = '{"Name": "John", "Office": "1st Ave", "Birth date": "1978-01-01"}'

d = json.loads(line)
d['Name'] # "John"

你需要在writerows之前创建一个项目列表:

names = [json.loads(x)['Name'] for x in lines]
writer.writerows(names)

【讨论】:

    猜你喜欢
    • 2021-10-29
    • 2016-02-12
    • 1970-01-01
    • 2016-11-06
    • 1970-01-01
    • 1970-01-01
    • 2020-11-06
    • 2019-02-01
    相关资源
    最近更新 更多