如何在 Python Cerberus 中将字符串强制转换为日期时间?
How to coerce string to datetime in Python Cerberus?
我正在尝试将字符串强制转换为日期,以便它可以验证日期数据类型,但它仍然 returns False
:
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
如有任何帮助,我们将不胜感激。
恐怕单独使用 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
我正在尝试将字符串强制转换为日期,以便它可以验证日期数据类型,但它仍然 returns False
:
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
如有任何帮助,我们将不胜感激。
恐怕单独使用 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