有一种用 定义递归映射的方法flask_restplus
,但限制是您必须对您的情况所需的最大递归级别做出假设。你不会想接触亚当和伊娃,对吗?
不要api.model
直接使用,而是编写一个递归构建该模型的方法,在每个递归调用中递减一个迭代编号参数。
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)
然后记得在使用编组器装饰您的方法时进行函数调用,如下所示:
@api.marshal_with(recursive_person_mapping())
def get(self):
...
注意圆括号!
还值得注意的是,'Person'+str(iteration_number)
如果您使用 swagger,这是强制性的。如果不添加迭代编号,您将最终导致递归限制溢出,从而导致内部服务器错误。在 swagger 之外,如果没有它,mapper 也会做得很好。
在对最大递归级别做出任意假设之后,在超出递归限制时自动通知管理员情况也是一个好主意。这可能是准备数据的方法的责任,而不是编组器本身的责任。