Нормализующая строка на сегодняшний день в Цербре
Я пытаюсь нормализовать строку как дату, чтобы при проверке он мог проверить тип данных даты.
from cerberus import Validator
from datetime import datetime
v = Validator()
v.schema = {'start_date': {'type': 'date','coerce':datetime.date}}
v.validate({'start_date': '2017-10-01'})
>>> False
но он все еще возвращает ложь. Я попытался использовать целое число, и оно работает, не уверен, почему преобразование даты не работает.
v = Validator()
v.schema = {'amount': {'type': 'integer','coerce': int}}
v.validate({'amount': '2'})
>>> True
Любая помощь будет оценена.
1 ответ
Решение
Я боюсь что datetime.date
одна не будет преобразовывать строку в значение даты. Если вы попробуете это в REPL, вот что вы получите:
>>> datetime.date('2017-10-01')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: descriptor 'date' requires a 'datetime.datetime' object but received a 'str'
Попробуйте что-то вроде этого:
from cerberus import Validator
from datetime import datetime
v = Validator()
to_date = lambda s: datetime.strptime(s, '%Y-%m-%d')
v.schema = {'start_date': {'type': 'datetime','coerce': to_date}}
v.validate({'start_date': '2017-10-01'})
>>> True