gpt4 book ai didi

flask - 棉花糖序列化嵌套与父字段

转载 作者:行者123 更新时间:2023-12-04 01:57:39 24 4
gpt4 key购买 nike

抱歉,如果之前有人问过这个问题,我实际上找不到解决方案或类似的问题(可能用错了词)。

我正在更新一个现有的 Flask API,它使用棉花糖和 peewee 从我们无法控制的客户端接收数据(无法更改 JSON 数据格式)。

数据格式是这样的:

{
"site_id": "0102931",
"update_date": "2018/02/11-09:33:23",
"updated_by": "chan1",
"crc": "a82131cf232ff120aaf00001293f",
"data": [{"num": 1,
"id": "09213/12312/1",
"chain": "chain2",
"operator": "0000122",
"op_name": "Fred",
"oid": "12092109300293"
},
{"num": 2,
"id": "09213/12312/2",
"chain": "chain1",
"operator": "0000021",
"op_name": "Melissa",
"oid": "8883390393"
}]
}

我们对主块中的任何内容都不感兴趣,但对 site_id 感兴趣,在反序列化以创建模型和存储数据时,必须将其复制到列表中的每个对象中。

这是peeewee中的模型:
class production_item(db.Model):
site_id = TextField(null=False)
id_prod = TextField(null=False)
num = SmallIntegerField(null=False)
chain = TextField(null=False)
operator = TextField(null=False)
operator_name = TextField(null=True)
order_id = TextField(null=False)

这是 marshamallow 模式:
class prodItemSchema(Schema):
num=String(required=True)
id=String(required=True)
chain=String(required=True)
operator=String(required=True)
op_name=String(required=False, allow_none=True)
oid=String(required=False, allow_none=True)

我找不到使用 load() 方法和 prodItemSchema 的预加载/加载后装饰器从主结构传递站点 ID 的方法,因此无法创建模型。另外,我希望棉花糖为我验证整个结构,而不是像现在在代码中那样在资源和模式之间进行两部分。

但是在文档中找不到一种方法来制作这样的东西,这可能吗?

最佳答案

在 marshmallow 中,可以使用 pre_dump 在序列化之前将值从父方案传递给其子方案。父方案上的装饰器设置 context .一旦设置了上下文,一个 function field可用于从父级获取值。

class Parent(Schema):
id = fields.String(required=True)
data = fields.Nested('Child', many=True)

@pre_dump
def set_context(self, parent, **kwargs):
self.context['site_id'] = parent['id']
return data

class Child(Schema):
site_id = fields.Function(inherit_from_parent)

def inherit_from_parent(child, context):
child['site_id'] = context['site_id']
return child

关于flask - 棉花糖序列化嵌套与父字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49505412/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com