3

是否可以使用相同的 json_mapping 为对象提供递归映射?

例子:

person_json_mapping = api.model('Person', {
    'name': fields.String(),
    'date_of_birth': fields.Date(),
    'parents': fields.List(fields.Nested(##person_json_mapping##))
    }

如何在 self 中使用person_json_mapping

4

1 回答 1

5

有一种用 定义递归映射的方法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 也会做得很好。

在对最大递归级别做出任意假设之后,在超出递归限制时自动通知管理员情况也是一个好主意。这可能是准备数据的方法的责任,而不是编组器本身的责任。

于 2017-10-04T10:13:07.067 回答