【发布时间】:2022-01-17 07:04:45
【问题描述】:
我有一个问题你们也许可以回答。
我有一个看起来像这样的 json 文件:
[
{
"address": "some address",
"full_time_school": false,
"name": "some name",
"official_id": "722154",
"school_type": "Grundschule",
"school_type_entity": "Grundschule",
"state": "BW"
},
{
"address": "some other address",
"name": "some other name",
"official_id": "722190",
"state": "BW"
}
]
关键是不是每个条目都有所有键。
我有一个如下所示的 flask-sqlalchemy 模型:
class School(db.Model):
__tablename__ = "school" # pragma: no cover
address = db.Column(db.String)
full_time_school = db.Column(db.Boolean)
name = db.Column(db.String)
official_id = db.Column(db.Integer)
school_type = db.Column(db.String)
school_type_entity = db.Column(db.String)
state = db.Column(db.String)
def __repr__(self):
return f"<name {self.name}"
我有一个 python 脚本可以将 json 条目添加到我的 postgresql 数据库中,如下所示:
from my_project import db
from my_project.models import School
import json
import os
# insert data
for filename in os.listdir("datamining"):
if filename.endswith(".json"):
file = open(os.path.join("datamining", filename))
print(f"Add schools from {filename.strip('.json')}")
data = json.load(file)
cleaned_data = {school["official_id"]: school for school in data}.values()
print(f"Adding {len(data)} schools to the database.")
for school in cleaned_data:
entry = School(
id=school["official_id"]
)
for key, value in school.items():
entry.key = value
db.session.add(entry)
db.session.commit()
file.close()
print("Added all schools!!!")
我不知道为什么,但不知何故,除了 official_id 字段之外,每个单元格都是 NULL。怎么样,我该如何解决?我现在已经走投无路了。非常感谢每一个指针或帮助。
编辑:
到目前为止,我发现entry.key 不会被解释为entry.state,但实际上会创建一个引用entry.key = "BW"。这是为什么呢?
【问题讨论】:
标签: python json python-3.x postgresql flask-sqlalchemy