我必须将类似时区的字符串转换"2012-11-01T04:16:13-04:00"
为Pythondatetime
对象。
我看到了dateutil
具有解析功能的模块,但是我真的不想使用它,因为它增加了依赖性。
那我该怎么办呢?我尝试了以下类似方法,但是没有运气。
datetime.datetime.strptime("2012-11-01T04:16:13-04:00", "%Y-%m-%dT%H:%M:%S%Z")
我必须将类似时区的字符串转换"2012-11-01T04:16:13-04:00"
为Pythondatetime
对象。
我看到了dateutil
具有解析功能的模块,但是我真的不想使用它,因为它增加了依赖性。
那我该怎么办呢?我尝试了以下类似方法,但是没有运气。
datetime.datetime.strptime("2012-11-01T04:16:13-04:00", "%Y-%m-%dT%H:%M:%S%Z")
Answers:
从Python 3.7开始,datetime.datetime.fromisoformat()
可以处理您的格式:
>>> import datetime
>>> datetime.datetime.fromisoformat('2012-11-01T04:16:13-04:00')
datetime.datetime(2012, 11, 1, 4, 16, 13, tzinfo=datetime.timezone(datetime.timedelta(days=-1, seconds=72000)))
在较旧的Python版本中,如果没有很多繁琐的手动时区定义,就不能做到。
Python不包含时区数据库,因为它会过时。取而代之的是,Python依靠外部库来提供正确配置的时区,而外部库的发布周期可能要快得多。
副作用是,这意味着时区解析也必须是外部库。如果dateutil
对您来说太重了,请改用iso8601
它,它会解析您的特定格式:
>>> import iso8601
>>> iso8601.parse_date('2012-11-01T04:16:13-04:00')
datetime.datetime(2012, 11, 1, 4, 16, 13, tzinfo=<FixedOffset '-04:00'>)
iso8601
是一个惊人的4KB小。比较该totpython-dateutil
的148KB。
从Python 3.2开始,Python可以处理基于简单偏移量的时区,并将在时间戳中%z
解析-hhmm
和+hhmm
时区偏移量。这意味着对于ISO 8601时间戳,您必须:
在时区中删除:
>>> from datetime import datetime
>>> iso_ts = '2012-11-01T04:16:13-04:00'
>>> datetime.strptime(''.join(iso_ts.rsplit(':', 1)), '%Y-%m-%dT%H:%M:%S%z')
datetime.datetime(2012, 11, 1, 4, 16, 13, tzinfo=datetime.timezone(datetime.timedelta(-1, 72000)))
Python版本15873中正在跟踪缺少正确的ISO 8601解析的问题。
datetime
可以包含iso8601
处理ISO 8601时区的功能-有点解析和两个tzinfo
子类。
原始问题中的代码有两个问题::
时区中不应存在a ,“ timezone as a offset”的格式字符串应为小写%z
而不是upper %Z
。
这在Python v3.6中对我有效
>>> from datetime import datetime
>>> t = datetime.strptime("2012-11-01T04:16:13-0400", "%Y-%m-%dT%H:%M:%S%z")
>>> print(t)
2012-11-01 04:16:13-04:00
print(t)
要在utc偏移量中加上冒号?
isoformat(sep=' ')
用于__str__
打印出作为UTC偏移功能“+ HH:MM”。使用时print(t.strftime("%Y-%m-%dT%H:%M:%S%z"))
将在时区中不带“:”的情况下打印。
2012-11-01T04:16:13-04:00
。OP正在寻求解析该表格。
我是Python的新手,但是找到了一种转换方法
2017-05-27T07:20:18.000-04:00
至
2017-05-27T07:20:18
无需下载新实用程序。
from datetime import datetime, timedelta
time_zone1 = int("2017-05-27T07:20:18.000-04:00"[-6:][:3])
>>returns -04
item_date = datetime.strptime("2017-05-27T07:20:18.000-04:00".replace(".000", "")[:-6], "%Y-%m-%dT%H:%M:%S") + timedelta(hours=-time_zone1)
我敢肯定有更好的方法可以做到这一点,而不必将字符串切得太多,但这已经完成了工作。