- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我使用 ZODB
创建了一个数据库,然后将其复制粘贴到另一台 PC。我想知道为什么每次我登录这个数据库(复制的)我都会得到这个错误:
no handlers could be found for logger (ZODB.FileStorage)
注意:程序不会中断,它只是将语句打印成红色,就好像它是一个错误。
这是什么烦人的消息,为什么每次登录时都会出现?
更新 no(1):什么是 python 日志系统?为什么我需要在我的应用程序中配置它?
注意:
我只使用 ZODB。
我的操作系统是 Windows XP sp2。
最佳答案
简答题
您不需要为您的应用程序配置它。这样做很有用。
长答案
logging模块是一个 python 模块,它允许任何 python 代码以与使用它的实际应用程序输出无关的方式记录信息。任何深度的库都可以导入日志模块、日志信息、警告、错误等,而不必确切知道用户将如何接收它们。
您所看到的是您自己的应用程序中缺少处理程序。 ZODB 显然是在记录信息,但是因为您没有定义处理程序,所以此记录信息只是蒸发到以太中。它通知您,如果您想查看一些日志记录信息,您应该定义一个处理程序
来自Logging Cookbook :
import logging
# create logger with 'spam_application'
logger = logging.getLogger('spam_application')
logger.setLevel(logging.DEBUG)
# create file handler which logs even debug messages
fh = logging.FileHandler('spam.log')
fh.setLevel(logging.DEBUG)
# create console handler with a higher log level
ch = logging.StreamHandler()
ch.setLevel(logging.ERROR)
# create formatter and add it to the handlers
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fh.setFormatter(formatter)
ch.setFormatter(formatter)
# add the handlers to the logger
logger.addHandler(fh)
logger.addHandler(ch)
此示例使用您的应用的名称创建一个记录器。然后它创建两种类型的处理程序。一个是文件处理程序,用于将 DEBUG 级别的日志写入文件。第二个是流处理程序,它将向您的控制台发送错误。
如果你想看到更详细的信息进入你的控制台,你可以将日志级别更改为信息:
ch = logging.StreamHandler()
ch.setLevel(logging.INFO)
还要注意“格式化程序”的概念。您可以为不同的处理程序设置不同的日志格式。
如果您至少在您的应用中创建了一个流处理程序,那么它将不再警告您尚未定义处理程序。
对于 python 2.7+,logging
模块包含一个 NullHandler
。它旨在在库(例如您的数据库库)中用作默认处理程序,当最终用户在没有任何日志记录处理程序的情况下使用库时(如您所做的那样),它会消除错误。因此,如果您根本不关心日志记录,只是想让它静音,您可以在自己的代码中添加一个 NullHandler
。建议实际设置日志记录,但这只是另一种选择:
Adding NullHandler to the logger
import logging
logging.getLogger('spam_application').addHandler(logging.NullHandler())
关于python - 复制的 ZODB 数据库上出现错误消息 "no handlers could be found for logger ZODB.FileStorage",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11191398/
在我的应用中,我使用 IntentService 发送短信。 @Override protected void onHandleIntent(Intent intent) { Bund
Handler(android.os.Handler.Callback) 已弃用,我应该改用什么? Handler handler = new Handler(new Handler.Callback
机器人Handler类包含此方法: public final boolean postAtTime (Runnable r, Object token, long uptimeMillis) 在给定时
我不明白怎么用这个方法, sensorManager.registerListener(SensorEventListener listener, Sensor sensor, int rate, H
请告诉我 handler.postAtTime 和 handler.postDelayed 在 android 中的区别,也请指导我何时使用 handler.postAtTime 以及何时使用 han
我有以下代码。 function myFun() { alert(5) } $(document).ready(fu
我有this jsfiddle 它使用 toggle event - 不要与 toggle 混淆- jQuery 版本设置为 EDGE 它突然停止工作并删除了我想要作为触发器的单元格,因为它显然恢复为
在我的应用程序中,我定义了一个自定义事件,我希望为其设置默认处理程序。如果任何 Controller /服务想要覆盖默认处理,他们可以通过添加自己的处理程序来实现。 为了实现这个场景,我在 $root
我在我的网页中使用了 jquery .toggle(between two functions) : $( ".cpUpbtnsclass" ).toggle(function() { c
我有this jsfiddle 它使用 toggle event - 不要与 toggle 混淆- jQuery 版本设置为 EDGE 它突然停止工作并删除了我想要作为触发器的单元格,因为它显然恢复为
我浏览了官方文档,但我似乎找不到 new Handler() 之间是否有任何区别和new Handler(Looper.myLooper()) new Handler() Default constr
当我在 faces-config.xml 文件中添加以下行时: " com.sun.facelets.FaceletViewHandler " eclipse 说: " view-handler re
当我使用 Handler.dispatchMessage(msg) 时,handleMessage(Message msg) 将在新线程上运行,但是当我使用 Handler.sendMessage(
如何禁用当前将模态库导航到下一张图像的鼠标滚轮处理程序和键盘箭头键? 这里是演示站点:http://blueimp.github.com/Bootstrap-Image-Gallery/ . 如果您单
我正在尝试关注 this关于 Win32 结构化异常处理的文章。这篇文章很老了,但仍然被认为是对该主题的一个很好的介绍。 我正在尝试从下面转载的文章中编译代码示例 - //==============
我正在尝试使用 HibernateValidator 使用 Spring 和 Hibernate 在 JSP 中验证一个简单的表单. JSP页面Temp.jsp如下(web.xml中的url ptte
问题几乎概括了它。我错误地导入了 java.util.logging 并且没有获得所需的功能。现在我解决了我的问题,但我想知道为什么 android 创建了两个 Handler 。我们可能会错误地导入
我有一个主页,其中有一个链接按钮。在其中一个内容页面中,我需要隐藏链接按钮并替换为图像按钮。图像按钮的单击事件处理程序应该与母版页中链接按钮的单击事件完全相同。那么有没有办法从内容页面中的图像按钮单击
我有一个用 2.5 编写的现有 Spring MVC 应用程序。 我想使用新的注释 Controller 。我在某种程度上发现它非常灵活并且可以满足我的其他需求。 我的问题是,我似乎无法将它们两者混合
使用最新的 XCode,我收到此错误: 'logInWithReadPermissions(_:handler:)' is deprecated: use logInWithReadPermissi
我是一名优秀的程序员,十分优秀!