Django给了我一些运行时警告(关于我没写过的代码)。
我怎样才能让Django给我一个堆栈跟踪,所以我可以看到是什么导致了这些?
/usr/local/lib/python2.7/dist-packages/django/db/models/fields/__init__.py:808:
RuntimeWarning: DateTimeField received a naive datetime (2012-07-19 09:36:16.161479)
while time zone support is active.
RuntimeWarning
答案 0 :(得分:16)
来自https://docs.djangoproject.com/en/1.10/topics/i18n/timezones/#code
的文档在开发过程中,您可以将此类警告转换为异常,并通过将以下内容添加到您的设置文件中来获取追溯:
import warnings
warnings.filterwarnings(
'error', r"DateTimeField .* received a naive datetime",
RuntimeWarning, r'django\.db\.models\.fields')
答案 1 :(得分:1)
您可以使用traceback.print_exception()
实现日志格式化程序并在日志中追溯警告消息。
您也可以参考此How do I use Django's logger to log a traceback when I tell it to?
答案 2 :(得分:-2)
这意味着您在django中启用了时区支持;但是你传递了一个没有任何时区信息的日期时间对象。
如果你想要django的时区支持,那么使用的日期时间对象应该是时区感知的。
documentation on timezone support提供了一种将日期时间对象转换为带有timzeones的对象的方法。
答案 3 :(得分:-3)
Django的消息来源告诉你刚刚发生了什么:
def get_prep_value(self, value):
value = self.to_python(value)
if value is not None and settings.USE_TZ and timezone.is_naive(value):
# For backwards compatibility, interpret naive datetimes in local
# time. This won't work during DST change, but we can't do much
# about it, so we let the exceptions percolate up the call stack.
warnings.warn(u"DateTimeField received a naive datetime (%s)"
u" while time zone support is active." % value,
RuntimeWarning)
default_timezone = timezone.get_default_timezone()
value = timezone.make_aware(value, default_timezone)
return value