您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

将所有错误记录到Django站点上的控制台或文件中

将所有错误记录到Django站点上的控制台或文件中

这有点极端,但是出于调试目的,您可以打开该DEBUG_PROPAGATE_EXCEPTIONS设置。这将允许您设置自己的错误处理。设置上述错误处理的最简单方法是覆盖sys.excepthook。这将终止您的应用程序,但是它将起作用。您可能需要做一些事情,以确保它不会杀死您的应用程序,但这取决于您要为其部署此平台的平台。无论如何,绝对不要在生产中使用它!

对于生产来说,几乎必须要有大量的错误处理。我使用的一种技术是这样的:

>>> def log_error(func):
...     def _call_func(*args, **argd):
...         try:
...             func(*args, **argd)
...         except:
...             print "error" #substitute your own error handling
...     return _call_func
...
>>> @log_error
... def foo(a):
...     raise AttributeError
...
>>> foo(1)
error
@H_404_6@

如果在视图上使用log_error作为装饰器,它将自动处理其中发生的任何错误

流程_@H_404_6@异常函数针对某些异常(例如,views.py中的assert(False))_@H_404_6@被调用,但流程异常并未针对诸如ImportErrors(例如:在urs.py中导入thisclassdoesnotexist)之类的其他错误而被调用。我是Django / Python的新手。这是因为运行时错误和编译时错误之间有区别吗?

在Python中,所有错误均为运行时错误。造成问题的原因是因为在调用视图之前导入模块时,这些错误会立即发生。我发布的第一种方法将捕获此类错误以进行调试。您可能可以为生产找到一些解决方案,但是我认为如果在生产应用程序中遇到ImportErrors(并且没有进行任何动态导入),则问题会更严重。

不过,像pylint这样的工具可以帮助您消除此类问题。

Go 2022/1/1 18:43:03 有375人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶