我是python的新手,我有一个json文件,我试图用它来创建一个使用python的数据结构。
以下是其中一行的示例:
[{'name': 'Nick', 'age': '35', 'city': 'New York'}...]
我将其读入内存,但不确定我需要采取哪些额外步骤才能使用它来创建表格。
这是我到目前为止所尝试的内容:
import json
import csv
from pprint import pprint
with open("/desktop/customer_records.json") as customer_records:
data=json.load(customer_records)
for row in data:
print(row)
理想情况下,我会采用以下格式:
Name Age City
Nick 35 New York
任何帮助将不胜感激。提前谢谢。
答案 0 :(得分:1)
您的问题没有精确指定,但如果您想生成可以插入MySQL的SQL,这里有一个将JSON转换为SQL语句序列的小程序:
#!/usr/bin/env python
import json
# Load data
with open("zz.json") as f:
data=json.load(f)
# Find all keys
keys = []
for row in data:
for key in row.keys():
if key not in keys:
keys.append(key)
# Print table definition
print """CREATE TABLE MY_TABLE(
{0}
);""".format(",\n ".join(map(lambda key: "{0} VARCHAR".format(key), keys)))
# Now, for all rows, print values
for row in data:
print """INSERT INTO MY_TABLE VALUES({0});""".format(
",".join(map(lambda key: "'{0}'".format(row[key]) if key in row else "NULL", keys)))
对于此JSON文件:
[
{"name": "Nick", "age": "35", "city": "New York"},
{"name": "Joe", "age": "21", "city": "Boston"},
{"name": "Alice", "city": "Washington"},
{"name": "Bob", "age": "49"}
]
生成
CREATE TABLE MY_TABLE(
city VARCHAR,
age VARCHAR,
name VARCHAR
);
INSERT INTO MY_TABLE VALUES('New York','35','Nick');
INSERT INTO MY_TABLE VALUES('Boston','21','Joe');
INSERT INTO MY_TABLE VALUES('Washington',NULL,'Alice');
INSERT INTO MY_TABLE VALUES(NULL,'49','Bob');
对于未来,请提出更具体的问题:)