我有以下代码可以使用{Year}/{Month}
之类的输入格式正常运行,除非涉及到1994/02
以下是示例代码
>>> import dateutil.parser as dtp
>>> dtp.parse('1994/01')
datetime.datetime(1994, 1, 29, 0, 0)
>>> dtp.parse('1994/03')
datetime.datetime(1994, 3, 29, 0, 0)
>>> dtp.parse('1994/02')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/Users/antony/.virtualenvs/comp-invest/lib/python2.7/site-packages/dateutil/parser.py", line 720, in parse
return DEFAULTPARSER.parse(timestr, **kwargs)
File "/Users/antony/.virtualenvs/comp-invest/lib/python2.7/site-packages/dateutil/parser.py", line 317, in parse
ret = default.replace(**repl)
ValueError: day is out of range for month
正如您所看到的,代码可以与1994/01
和1994/03
一起使用,但在1994/02
时失败
这与闰年有什么关系吗?但更重要的是,如何解决这个问题并使我的代码再次运行?
由于
答案 0 :(得分:12)
dtp.parse
正在填写当前日期的缺失日期。您在2013/01/29上运行了代码,在2月份(即1994/02/29)不存在第29天。
请改用:
dtp.parse('1994/01'+'/01')
无论代码何时执行,它都会给出一致的结果(月的第一天)。
答案 1 :(得分:1)
此后a bug in dateutil已修复。版本2.5.0及更高版本将不再出现此问题。
如果你必须使用早期版本,我认为处理事情的“正确”方法是指定default
参数:
from dateutil.parser import parse
from datetime import datetime, date
# First of the current month, at midnight.
default_date = datetime.combine(date.today(), datetime.min.time()).replace(day=1)
dt = parse('1994/01', default=default_date)
这将默认为当月的第1天而不是当天。