Нормализующая строка на сегодняшний день в Цербре - PullRequest
0 голосов
/ 02 мая 2018

Я пытаюсь нормализовать строку как дату, чтобы при проверке она могла проверять тип данных даты.

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

но все равно возвращает false. Я попытался использовать целое число, и оно работает, не уверен, почему преобразование даты не работает.

v = Validator()
v.schema = {'amount': {'type': 'integer','coerce': int}}
v.validate({'amount': '2'})
>>> True

Любая помощь будет оценена.

Ответы [ 2 ]

0 голосов
/ 13 мая 2019

Может быть, этот способ лучше использовать:

def to_date(s):
    return datetime.strptime(s, '%Y-%m-%d')
0 голосов
/ 03 мая 2018

Боюсь, что 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
...