我无法在 jsonschema 中使用“日期”进行类型验证
myschema = {
"$schema": "http://json-schema.org/draft-04/schema#",
"type": "object",
"self": {
"primary_key": ["email"]
},
"properties": {
"email": {
"pattern": "[^@]+@[^@]+\.[^@]+"
},
"dob": {
"description": "Date of Birth YYYY-MM-DD",
"type": "date"
}
}
}
当我使用上面的模式执行下面的代码时
from jsonschema import validate
validate({ "dob": "2001-02-30"}, myschema)
得到如下错误轨迹
Unhandled Exception: 'date' is not valid under any of the given schemas
Failed validating 'anyOf' in schema['properties']['properties']['additionalProperties']['properties']['type']:
{'anyOf': [{'$ref': '#/definitions/simpleTypes'},
{'items': {'$ref': '#/definitions/simpleTypes'},
'minItems': 1,
'type': 'array',
'uniqueItems': True}]}
On instance['properties']['dob']['type']:
'date'
更新:日期似乎是一种格式而不是类型,但它仍然让我输入无效日期。我可以在 jsonschema 代码中清楚地看到它尝试使用 datetime 来解析它,但我无法在那里设置断点。
最佳答案
date
应该用作 "format" ,而不是“类型”:
"dob": {
"description": "Date of Birth YYYY-MM-DD",
"type": "string",
"format": "date"
}
然后,要检查格式,请使用:
from jsonschema import validate, FormatChecker
validate({"dob": "2001-02-30"}, myschema, format_checker=FormatChecker())
关于python - 无法在 jsonschema 中使用日期验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40846886/