我在姜戈使用ReportLab。我有一个包含以下字段的模型:
time_stamp = models.DateTimeField(auto_now_add=True)并且我在settings.py中的TIME_ZONE变量被设置为:
Africa/Johannesburg我使用一个表单集来填充这个模型。time_stamp字段以正确的时区正确保存,但当我将time_stamp放入我的ReportLab pdf中时,时区被设置为协调世界时。
例如:保存的模型中的time_stamp (因为str(time_stamp)[:19]是:
2015-03-04 07:57:28但pdf文档中的time_stamp (如str(time_stamp)[:19]所示:
2015-03-04 05:57:28恰好提前2小时(非洲/约翰尼斯堡为UTC +2小时)。
如何设置ReportLab的时区?在生成pdf时,应该在settings.py中指定还是在views.py中指定?如果没有解决方案,如何在time_stamp中增加2小时
一些回答建议使用default=datetime.datetime.now()更改auto_now_add=True,但这会在迁移数据库时产生警告(使用朴素的表达式)。
发布于 2015-03-04 18:17:25
我不是Reportlab的用户,但总的来说,我不认为设置USE_TZ=False是解决问题的正确方法。将它设置回True,而不是截断您的时间戳,如下所示:
str(time_stamp)[:19]您应该尝试在模板中应用Django的date template filter,例如:
{{ time_stamp|date:"SHORT_DATETIME_FORMAT" }}Django处理时区的方式可能会让人感到困惑。但最佳实践是以UTC格式将时间戳保存在数据库中。你可以参考Django的时区常见问题解答:
https://docs.djangoproject.com/en/dev/topics/i18n/timezones/#time-zones-faq
https://stackoverflow.com/questions/28847693
复制相似问题