Dec*_*pol 3 python json flask flask-restplus
是否可以使用相同的 json_mapping 为对象提供递归映射?
示例:
person_json_mapping = api.model('Person', {
'name': fields.String(),
'date_of_birth': fields.Date(),
'parents': fields.List(fields.Nested(##person_json_mapping##))
}
Run Code Online (Sandbox Code Playgroud)
如何在 self 内部使用person_json_mapping?
有一种使用 定义递归映射的方法flask_restplus,但有一个限制,即您必须对您的情况所需的最大递归级别做出假设。你不会想联系亚当和伊娃吧?
不要api.model直接使用,而是编写一个递归地构建该模型的方法,在每个递归调用中递减 iteration_number 参数。
def recursive_person_mapping(iteration_number=10):
person_json_mapping = {
'name': fields.String(),
'date_of_birth': fields.Date()
}
if iteration_number:
person_json_mapping['parents'] = fields.List(fields.Nested(recursive_person_mapping(iteration_number-1)))
return api.model('Person'+str(iteration_number), person_json_mapping)
Run Code Online (Sandbox Code Playgroud)
然后记住在使用编组器修饰方法时进行函数调用,如下所示:
@api.marshal_with(recursive_person_mapping())
def get(self):
...
Run Code Online (Sandbox Code Playgroud)
注意圆括号!
还值得注意的是,'Person'+str(iteration_number)如果您使用 swagger,则这是强制性的。如果不添加 iteration_number ,您最终会出现递归限制溢出,从而导致内部服务器错误。除了 swagger 之外,mapper 没有它也能做得很好。
在对最大递归级别进行任意假设后,在超出递归限制时自动通知管理员可能是一个好主意。这可能是准备数据的方法的责任,而不是编组器本身的责任。
| 归档时间: |
|
| 查看次数: |
1126 次 |
| 最近记录: |