我使用cerberus来验证我的数据,例如:
document = {
"region": 77,
"drivers": {
"data": [
{ "birthday": "2004-01-01", "kbm_class": "3", "driving_experience": 10 },
{ "birthday": "1988-01-01", "kbm_class": "3", "driving_experience": 10 }],
"type": "limited"
},
"engine_power": 80,
"is_taxi": False
}
我使用这样的方案:
schema = {
'engine_power': {'type': 'integer'},
'region': {'type': 'integer'},
'is_taxi': {'type': 'boolean'},
'drivers': {
'schema': {
'type': {'type': 'string'},
'data': {
'type': 'list',
'schema': {
'type': 'dict',
'schema': {
'birthday': {'type': 'string', 'validator': validate_age},
'kbm_class': {'type': 'string'},
'driving_experience': {'type': 'integer'}
}
}
}
}
}
}
当我得到一个错误对象时,它有太多的嵌套:Cerberus 为每个嵌套级别创建一个列表:
{'drivers': [{'data': [{0: [{'birthday': ['driver too young']}]}]}]}
我可以得到类似的东西:
{'drivers': {'data': [{'birthday': ['driver too young']}]}}