对于给定的日期字符串,例如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)))
我不敢相信datetime
或pandas
中没有任何方法可以将与时区相关的偏移量应用于日期时间并返回普通的UTC日期时间。
如何应用tzinfo
偏移量/增量,以使所得时区为普通UTC(tzinfo=None
)?
答案 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