gpt4 book ai didi

python - 如何使 cerberus 所需规则取决于条件

转载 作者:太空宇宙 更新时间:2023-11-03 11:17:40 27 4
gpt4 key购买 nike

我有一个很大的 json 文档,如果其他字段具有精确值,则应该需要其中一些字段。例如

document = {'is_realty_address': False, 'postcode': 111111}

如果 is_realty_address == False,则必须提供邮政编码。所有规则(“必需”除外)都应用于文档中存在的字段,所以我的自定义规则是无声的,当我有

document = {'is_realty_address': False}

of-rules 对我的情况没有帮助,因为我有很多“条件要求”字段,这些字段取决于许多不同的字段。因此,不规则会使我的架构复杂化。依赖项也不起作用。我试过:

{'postcode': {'dependencies': {'is_realty_address': False}, 'required': True}}

如果邮政编码没有出现在文档中,无论 is_realty_address 的值是什么,都会返回错误

v = Validator()
print(v.validate({'is_realty_address': False}, schema))
print(v.errors)

print(v.validate({'is_realty_address': True}, schema))
print(v.errors)

此代码返回:

False
{'postcode': ['required field']}
False
{'postcode': ['required field']}

我还尝试实现验证方法:

def _validate_conditional_required(self, conditional_required, field, value):
"""
:param conditional_required:
:param field:
:param value:
:return:
The rule's arguments are validated against this schema:
{'type': 'dict'}
"""
for conditional_field, conditional_value in conditional_required.items():
if self.document[conditional_field] == conditional_value and field not in self.document:
self._error(field, errors.REQUIRED_FIELD)

有架构

schema = {
'is_realty_address': {'required': True, 'type': 'boolean'},
'postcode': {'conditional_required': {'is_realty_address': False}},
}

但如果“邮政编码”不在文档中,则此规则不会运行。

有什么方法可以设置“条件要求”规则吗?我想看这段代码:

schema = {
'is_realty_address': {'required': True, 'type': 'boolean'},
'postcode': {'conditional_required': {'is_realty_address': False}},
}
v = Validator()
print(v.validate({'is_realty_address': False}, schema))
print(v.errors)

print(v.validate({'is_realty_address': True}, schema))
print(v.errors)

返回:

True

False
{'postcode': ['required field']}

最佳答案

我想通了,我的问题可以通过结合“排除”和“一个”规则来解决

schema = {
'is_realty_address': {
'required': True, 'type': 'boolean',
'oneof': [{'excludes': 'postcode', 'allowed': [False]}, {'allowed': [True]}]
},
'postcode': {'type': 'integer', 'required': True}}
v = Validator()
print(v.validate({'is_realty_address': True}, schema))
print(v.errors)

print(v.validate({'is_realty_address': False, 'postcode': 111111}, schema))
print(v.errors)

此代码返回:

False
{'postcode': ['required field']}
False
{'is_realty_address': [{'oneof': ['none or more than one rule validate', {'oneof definition 1': ['unallowed value False'], 'oneof definition 0': ["'postcode' must not be present with 'is_realty_address'"]}]}]}

因此,模式不会因该变体而变得非常复杂。

关于python - 如何使 cerberus 所需规则取决于条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48789686/

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