在Python中将时区偏移量应用于日期时间

时间:2018-09-17 15:58:37

标签: python pandas datetime timezone timezone-offset

对于给定的日期字符串,例如2009-01-01T12:00:00+0100,我想要UTC日期时间对象。

from datetime import datetime 
datetime.strptime("2013-03-21T14:19:42+0100", "%Y-%m-%dT%H:%M:%S%z")

返回

datetime.datetime(2013, 3, 21, 14, 19, 42, tzinfo=datetime.timezone(datetime.timedelta(0, 3600)))

我不敢相信datetimepandas中没有任何方法可以将与时区相关的偏移量应用于日期时间并返回普通的UTC日期时间。

如何应用tzinfo偏移量/增量,以使所得时区为普通UTC(tzinfo=None)?

2 个答案:

答案 0 :(得分:2)

这感觉有点脏,但是确实有用

from datetime import datetime
orig_dt = datetime.strptime("2013-03-21T14:19:42+0100", "%Y-%m-%dT%H:%M:%S%z")  # datetime.datetime(2013, 3, 21, 14, 19, 42, tzinfo=datetime.timezone(datetime.timedelta(0, 3600)))
utc_time_value = orig_dt - orig_dt.utcoffset()
utc_dt = utc_time_value.replace(tzinfo=None)  # datetime.datetime(2013, 3, 21, 13, 19, 42)

答案 1 :(得分:1)

这是实际的代码(内置):

from datetime import datetime, timezone, timedelta

return datetime(yy, mm, dd, hh, min, ss, 0, timezone(timedelta(hours=5)))       # +0500
# or
return datetime(yy, mm, dd, hh, min, ss, 0, timezone(timedelta(seconds=18000))) # +0500