我正在尝试在Python中生成RFC 3339 UTC时间戳。到目前为止,我已经能够做到以下几点:
>>> d = datetime.datetime.now()
>>> print d.isoformat('T')
2011-12-18T20:46:00.392227
我的问题是设置UTC偏移。
根据docs,类方法datetime.now([tz])
采用可选的tz
参数,其中tz must be an instance of a class tzinfo subclass
和datetime.tzinfo
为an abstract base class for time zone information objects.
这就是我迷路的地方 - 为什么tzinfo是一个抽象类,我该如何实现呢?
(注意:在PHP中它就像timestamp = date(DATE_RFC3339);
一样简单,这就是为什么我无法理解为什么Python的方法如此错综复杂......)
答案 0 :(得分:37)
时区是一种痛苦,这可能是他们选择不将它们包含在日期时间库中的原因。
尝试pytz,它有你正在寻找的tzinfo: http://pytz.sourceforge.net/
您需要先创建datetime
对象,然后按如下所示应用时区,然后您的.isoformat()
输出将包含所需的UTC偏移量:
d = datetime.datetime.utcnow()
d_with_timezone = d.replace(tzinfo=pytz.UTC)
d_with_timezone.isoformat()
'2017-04-13T14:34:23.111142 + 00:00'
或者,只需使用UTC,并在末尾抛出“Z”(对于 Zulu 时区),将“时区”标记为UTC。
d = datetime.datetime.utcnow() # <-- get time in UTC
print d.isoformat("T") + "Z"
'2017-04-13T14:34:23.111142Z'
答案 1 :(得分:24)
在Python 3.3 +中:
>>> from datetime import datetime, timezone
>>> local_time = datetime.now(timezone.utc).astimezone()
>>> local_time.isoformat()
'2015-01-16T16:52:58.547366+01:00'
在较旧的Python版本中,如果您只需要一个表示当前UTC时间的日期时间对象,那么您可以define a simple tzinfo subclass as shown in the docs to represent UTC timezone:
from datetime import datetime
utc_now = datetime.now(utc)
print(utc_now.isoformat('T'))
# -> 2015-05-19T20:32:12.610841+00:00
您还可以使用tzlocal
module获取代表当地时区的pytz
时区:
#!/usr/bin/env python
from datetime import datetime
from tzlocal import get_localzone # $ pip install tzlocal
now = datetime.now(get_localzone())
print(now.isoformat('T'))
它适用于Python 2和3。
答案 2 :(得分:7)
Further down在您链接的同一个文档中,它解释了如何实现它,提供了一些示例,包括UTC
类(代表UTC)的完整代码,FixedOffset
class(表示与UTC具有固定偏移量的时区,而不是具有DST和whatnot的时区),以及其他一些时区。
答案 3 :(得分:5)
我经常使用RFC3339日期时间格式,但我找到了一个合适的解决方案来转换date_string&lt; =&gt; datetime_object在两个方向上。
你需要两个不同的外部模块,因为其中一个只能在一个方向进行转换(不幸的是):
首先安装:
sudo pip install rfc3339
sudo pip install iso8601
然后包括:
import datetime # for general datetime object handling
import rfc3339 # for date object -> date string
import iso8601 # for date string -> date object
为了不需要记住哪个模块是哪个方向,我写了两个简单的辅助函数:
def get_date_object(date_string):
return iso8601.parse_date(date_string)
def get_date_string(date_object):
return rfc3339.rfc3339(date_object)
您可以在代码中轻松使用,如下所示:
input_string = '1989-01-01T00:18:07-05:00'
test_date = get_date_object(input_string)
# >>> datetime.datetime(1989, 1, 1, 0, 18, 7, tzinfo=<FixedOffset '-05:00' datetime.timedelta(-1, 68400)>)
test_string = get_date_string(test_date)
# >>> '1989-01-01T00:18:07-05:00'
test_string is input_string # >>> True
Heureka!现在您可以轻松地( haha )以可用的格式使用日期字符串和日期字符串。
答案 4 :(得分:1)
{2.}}包适用于Python 2.X和3.X.它实现了tzinfo
的具体子类,以及其他服务,因此您不必这样做。
添加UTC偏移量: 导入日期时间 进口pytz
dt = datetime.datetime(2011, 12, 18, 20, 46, 00, 392227)
utc_dt = pytz.UTC.localize(dt)
现在这个:
print utc_dt.isoformat()
会打印:
2011-12-18T20:46:00.392227+00:00
答案 5 :(得分:0)
答案 6 :(得分:0)
你确实可以使用内置的 datetime模块。如 @ruakh mentions,有一些例子 显示如何的页面。如果您查看该部分 tzinfo你好 查看显示许多不同用例的长示例。这是一个代码 您正在寻找,即生成RFC 3339 UTC时间戳。
from datetime import tzinfo, timedelta, datetime
import time as _time
ZERO = timedelta(0)
STDOFFSET = timedelta(seconds=-_time.timezone)
if _time.daylight:
DSTOFFSET = timedelta(seconds=-_time.altzone)
else:
DSTOFFSET = STDOFFSET
DSTDIFF = DSTOFFSET - STDOFFSET
class LocalTimezone(tzinfo):
def utcoffset(self, dt):
if self._isdst(dt):
return DSTOFFSET
else:
return STDOFFSET
def dst(self, dt):
if self._isdst(dt):
return DSTDIFF
else:
return ZERO
def tzname(self, dt):
return _time.tzname[self._isdst(dt)]
def _isdst(self, dt):
tt = (dt.year, dt.month, dt.day,
dt.hour, dt.minute, dt.second,
dt.weekday(), 0, 0)
stamp = _time.mktime(tt)
tt = _time.localtime(stamp)
return tt.tm_isdst > 0
Local = LocalTimezone()
d = datetime.now(Local)
print d.isoformat('T')
# which returns
# 2014-04-28T15:44:45.758506-07:00
答案 7 :(得分:0)
在现代(3.x)python上,要获取RFC 3339 UTC时间,您所需要做的就是使用datetime和这一行(无需第三方模块):
import datetime
datetime.datetime.now(datetime.timezone.utc).isoformat()
结果类似于:'2019-06-13T15:29:28.972488 + 00:00'
此ISO 8601字符串也兼容RFC3339。