1

我正在尝试使用 Cerberus 使用本文anyof_schema中提出的规则来验证包含字符串或字典的列表:

from cerberus import Validator

A = {'type': 'dict',
     'schema': {'name': {'type': 'string', 'required': True},
                'run': {'type': 'string', 'required': True}}}
B = {'type': 'string', 'empty': False}

schema = {
    'some_field': {
        'type': 'list',
        'anyof_schema': [A, B]
    }
}

v = Validator(schema)

challenge = {
    'some_field': ['simple string 1', {'name': 'some name', 'run': 'some command'}]
}

print(v.validate(challenge))
print(v.errors)

但验证失败,输出:

False
{'some_field': ['no definitions validate', {'anyof definition 0': [{0: ['must be of dict type']}], 'anyof definition 1': [{1: ['must be of string type']}]}]}

似乎该anyof_schema规则仅在提供的集合中的所有模式都描述相同的数据类型(例如字典)时才有效。

为什么anyof_schema规则在我的情况下失败,我该如何解决这个问题?

我正在使用 Python 3.5.3 和 Cerberus 1.3.1

4

1 回答 1

1

问题是您的架构看起来像这样扩展:

{"some_field": {
    "anyof" : [
        {"schema": …},
        {"schema": …},
    ]
}}

这意味着整个列表仅针对anyof包含的每个规则集的一个变体进行验证。

因此,您只需要在层次结构中交换anyofschema

{"some_field": {
    "schema" : {
        "anyof":[
            {"type": "dict", …},
            {"type": "str", …},
        ]
    }
}}

这将根据允许的变体验证列表中的每个项目,因此这些变体可以是各种“形状”。

于 2019-06-02T13:57:21.397 回答