【发布时间】:2014-03-28 23:04:35
【问题描述】:
我有一个关于烧瓶宁静扩展的问题。我刚开始使用它并面临一个问题。我有flask-sqlalchemy 连接多对一关系的实体,我希望那个宁静的端点使用编组器返回父实体及其在json 中的所有子实体。就我而言, Set 包含许多参数。我查看了flask-restful docs,但没有任何解释如何解决这个问题。
似乎我遗漏了一些明显的东西,但无法找到任何解决方案。 这是我的代码:
# entities
class Set(db.Model):
id = db.Column("id", db.Integer, db.Sequence("set_id_seq"), primary_key=True)
title = db.Column("title", db.String(256))
parameters = db.relationship("Parameters", backref="set", cascade="all")
class Parameters(db.Model):
id = db.Column("id", db.Integer, db.Sequence("parameter_id_seq"), primary_key=True)
flag = db.Column("flag", db.String(256))
value = db.Column("value", db.String(256))
set_id = db.Column("set_id", db.Integer, db.ForeignKey("set.id"))
# marshallers
from flask.ext.restful import fields
parameter_marshaller = {
"flag": fields.String,
"value": fields.String
}
set_marshaller = {
'id': fields.String,
'title': fields.String,
'parameters': fields.List(fields.Nested(parameter_marshaller))
}
# endpoint
class SetApi(Resource):
@marshal_with(marshallers.set_marshaller)
def get(self, set_id):
entity = Set.query.get(set_id)
return entity
restful_api = Api(app)
restful_api.add_resource(SetApi, "/api/set/<int:set_id>")
现在当我打电话给/api/set/1 时,出现服务器错误:
TypeError: 'Set' object is unsubscriptable
所以我需要一种方法来正确定义端点返回此 json 的 set_marshaller:
{
"id": : "1",
"title": "any-title",
"parameters": [
{"flag": "any-flag", "value": "any-value" },
{"flag": "any-flag", "value": "any-value" },
.....
]
}
感谢您的帮助。
【问题讨论】:
标签: python json rest flask flask-restful