>>> import dateutil.parser, dateutil.tz as tz
>>> dateutil.parser.parse('2017-08-09 10:45 am').replace(tzinfo=tz.gettz('America/New_York'))
datetime.datetime(2017, 8, 9, 10, 45, tzinfo=tzfile('/usr/share/zoneinfo/America/New_York'))
那真的是我们应该设置默认时区进行解析的方式吗?我已经阅读了parser和examples的文档,但我似乎找不到任何说法,“这是如何设置dateutil.parser.parse的默认时区”,甚至是它
因为当工作时,如果提供了区域,有些情况会出错。这是否意味着我们应该这样做?
>>> d = dateutil.parser.parse('2017-08-09 10:45 am +06:00')
>>> d = d.replace(tzinfo=d.tzinfo or tz.gettz('America/Chicago'))
因为那也很笨重。
解析时设置默认时区的推荐方法是什么?
答案 0 :(得分:1)
充实保罗的评论 - 因为datetime
必须在至少一年,一月和一天,dateutil已经有一个默认值:
>>> from datetime import datetime
>>> datetime.now()
datetime.datetime(2017, 10, 13, 15, 16, 13, 548750)
>>> dateutil.parser.parse('2017')
datetime.datetime(2017, 10, 13, 0, 0)
鉴于此,适当的选择是创建一个包含时区的default
,或者只是当前日期,或者任何有意义的日期:
>>> dateutil.parser.parse('2017', default=datetime(2017, 10, 13, tzinfo=tz.gettz('America/New_York')))
当然,您可以将默认值存储为合理的内容,例如default_datetime
或其他内容,然后它变为:
>>> dateutil.parser.parse('2017', default=default_datetime)
答案 1 :(得分:1)
基本上有两种“正确”的方法可以做到这一点。您可以看到dateutil
的问题跟踪器上显示Issue #94,并且“设置默认时区”被确定为超出范围,因为这可以轻松完成使用解析器返回的信息(因此无需将其构建到解析器本身)。这两种方式是:
提供具有时区的default
日期。如果您不关心default
日期是什么,您可以指定一些日期文字并完成它。如果你希望行为与dateutil
的默认行为基本相同(从“今天午夜的日期”中替换丢失的元素),你必须有一些样板:
from datetime import datetime, time
from dateutil import tz, parser
default_date = datetime.combine(datetime.now(),
time(0, tzinfo=tz.gettz("America/New_York")))
dt = parser.parse(some_dt_str, default=default_date)
将您的第二种方法与.replace
:
from dateutil import parser
def my_parser(*args, default_tzinfo=tz.gettz("America/New_York"), **kwargs):
dt = parser.parse(*args, **kwargs)
return dt.replace(tzinfo=dt.tzinfo or default_tzinfo)
最后一个可能比第一个稍微干净,但如果在紧密循环中运行会略微降低性能(因为第一个只需要创建一次的默认日期),但dateutil
的解析器是实际上非常慢,所以如果你在一个紧凑的循环中运行它,那么额外的日期构造可能是你的问题中最少的。