如何将时区感知的datetime对象转换为本地时区的等效非时区感知datetime?
我的特定应用程序使用Django(尽管这实际上是一个通用的python问题):
import iso8601
。。。。
date_str="2010-10-30T17:21:12Z"
。。。。
d = iso8601.parse_date(date_str)
foo = app.models.FooModel(the_date=d)
foo.save()
这会导致Django抛出一个错误:
raise ValueError("MySQL backend does not support timezone-aware datetimes.")
我需要的是:
d = iso8601.parse_date(date_str)
local_d = SOME_FUNCTION(d)
foo = app.models.FooModel(the_date=local_d)
一些函数是什么?
一般来说,要将任意时区感知的日期时间转换为原始(本地)日期时间,我将使用
pytz
模块和astimezone
转换为本地时间,并使用replace
使日期时间变为原始:但是,由于您的特定日期时间似乎位于UTC时区,您可以这样做:
顺便说一下,最好将日期时间存储为原始的UTC日期时间,而不是原始的本地日期时间。这样,您的数据是本地时间不可知的,您只在必要时转换为本地时间或任何其他时区。类似于尽可能多地使用unicode,并且只在必要时才进行编码。
因此,如果您同意以原始UTC格式存储日期时间是最好的方法,那么您只需要定义:
在Django的最新版本(至少1.4.1)中:
一个可移植的健壮解决方案应该使用tz数据库。要将本地时区获取为^{} } module :
tzinfo
对象,use ^{注意:可能很容易使用如下内容:
但是,如果本地时区有一个变量utc offset,但python在给定平台上不使用历史时区数据库,则可能会失败。
相关问题 更多 >
编程相关推荐