Python棉花糖:字典验证错误

GLR*_*GLR 5 python orm validationerror marshmallow

我对棉花糖很陌生,但我的问题是指处理类似 dict 的对象的问题。Marshmallow 文档中没有可行的示例。我在堆栈溢出原始问题中遇到了一个简单的例子,这是答案的原始代码,假设这应该很简单

from marshmallow import Schema, fields, post_load, pprint

class UserSchema(Schema):
    name = fields.String()
    email = fields.Email()
    friends = fields.List(fields.String())

class AddressBookSchema(Schema):
    contacts =fields.Dict(keys=fields.String(),values=fields.Nested(UserSchema))

@post_load
def trans_friends(self, item):
    for name in item['contacts']:
        item['contacts'][name]['friends'] = [item['contacts'][n] for n in item['contacts'][name]['friends']]


data = """
   {"contacts": { 
        "Steve": {
            "name": "Steve",
            "email": "steve@example.com",
            "friends": ["Mike"]
        },
        "Mike": {
            "name": "Mike",
            "email": "mike@example.com",
            "friends": []
        }
   }
}
"""

deserialized_data = AddressBookSchema().loads(data)
pprint(deserialized_data)
Run Code Online (Sandbox Code Playgroud)

但是,当我运行代码时,我得到以下 NoneType 值

`None`
Run Code Online (Sandbox Code Playgroud)

输入尚未编组。

我正在使用棉花糖 3.0.0b20 的最新测试版。即使它看起来如此简单,我也找不到使这项工作的方法。该信息似乎表明框架正在使用嵌套字典。

目前,我正在为flask 编写一个编目应用程序,我在其中接收JSON 消息,但我无法事先真正指定模式。我的具体问题如下:

data = """
   {"book": { 
        "title": {
            "english": "Don Quixiote",
            "spanish": "Don Quijote"
            },
        "author": {
            "first_name": "Miguel",
            "last_name": "Cervantes de Saavedra"
            }
        },
    "book": { 
        "title": {
            "english": "20000 Leagues Under The Sea",
            "french": "20000 Lieues Sous Le Mer",
            "japanese": "????20000???",
            "spanish": "20000 Leguas Bajo El Mar",
            "german": "20000 Meilen unter dem Meeresspiegel",
            "russian": "20000 ??? ??? ?????"
            },
        "author": {
            "first_name": "Jules",
            "last_name": "Verne"
            }
        }
    }
Run Code Online (Sandbox Code Playgroud)

这只是玩具数据,但说明字典中的键不是固定的,它们在数字和文本上会发生变化。

所以问题是为什么我在一个简单的已经工作的例子中得到验证错误,以及是否可以使用棉花糖框架来验证我的数据,

谢谢

Jér*_*ôme 6

您的代码中有两个问题。

第一个是 post_load 装饰器的缩进。你在这里复制代码时引入了它,但是你运行的代码中没有它,否则你不会得到None.

第二个是由于棉花糖 3 中记录的更改。 pre/post_load/dump 函数应该返回值而不是改变它。

这是一个工作版本。我还重新设计了装饰器:

from marshmallow import Schema, fields, post_load, pprint

class UserSchema(Schema):
    name = fields.String()
    email = fields.Email()
    friends = fields.List(fields.String())

class AddressBookSchema(Schema):
    contacts = fields.Dict(keys=fields.String(),values=fields.Nested(UserSchema))

    @post_load
    def trans_friends(self, item):
        for contact in item['contacts'].values():
            contact['friends'] = [item['contacts'][n] for n in contact['friends']]
        return item


data = """
    {
        "contacts": { 
            "Steve": {
                "name": "Steve",
                "email": "steve@example.com",
                "friends": ["Mike"]
            },
            "Mike": {
                "name": "Mike",
                "email": "mike@example.com",
                "friends": []
            }
        }
    }
"""

deserialized_data = AddressBookSchema().loads(data)
pprint(deserialized_data)
Run Code Online (Sandbox Code Playgroud)

最后,Dictin marshmallow 2 没有键/值验证功能,因此它只会默默地忽略keysandvalues参数并且不执行任何验证。