python的logging 模块的propagate设置(pythOn)

网友投稿 411 2022-09-03


python的logging 模块的propagate设置(pythOn)

代码:

import loggingimport sysLOG_FORMAT = '[%(asctime)s PID:%(process)d %(levelname)s %(filename)s %(funcName)s] %(message)s'sh = logging.StreamHandler(sys.stdout)formatter = logging.Formatter(LOG_FORMAT)sh.setFormatter(formatter)sh2 = logging.StreamHandler(sys.stdout)formatter2 = logging.Formatter(LOG_FORMAT)sh2.setFormatter(formatter2)sh3 = logging.StreamHandler(sys.stdout)formatter3 = logging.Formatter(LOG_FORMAT)sh3.setFormatter(formatter3)lab_logger = logging.getLogger()lab_logger.handlers = [sh]lab_logger_2 = logging.getLogger('a')lab_logger_2.handlers = [sh2]# lab_logger_2.propagate=Falselab_logger_3 = logging.getLogger('a.b')lab_logger_3.handlers = [sh3]# lab_logger_3.propagate=Falselab_logger_3.warning('xxxxxxxxxxxxxxxxxxxxx')

运行结果:

修改:

import loggingimport sysLOG_FORMAT = '[%(asctime)s PID:%(process)d %(levelname)s %(filename)s %(funcName)s] %(message)s'sh = logging.StreamHandler(sys.stdout)formatter = logging.Formatter(LOG_FORMAT)sh.setFormatter(formatter)sh2 = logging.StreamHandler(sys.stdout)formatter2 = logging.Formatter(LOG_FORMAT)sh2.setFormatter(formatter2)sh3 = logging.StreamHandler(sys.stdout)formatter3 = logging.Formatter(LOG_FORMAT)sh3.setFormatter(formatter3)lab_logger = logging.getLogger()lab_logger.handlers = [sh]lab_logger_2 = logging.getLogger('a')lab_logger_2.handlers = [sh2]# lab_logger_2.propagate=Falselab_logger_3 = logging.getLogger('a.b')lab_logger_3.handlers = [sh3]lab_logger_3.propagate=Falselab_logger_3.warning('xxxxxxxxxxxxxxxxxxxxx')

运行结果:

参考官方文档:

​​https://docs.python.org/zh-cn/3/library/logging.html​​

可以知道,logging.getLogger()获得的是ROOT记录器,logging.getLogger('a')获得的是名为'a'的记录器,logging.getLogger('a.b')获得的是名为'a.b'的记录器。

从logging的记录器名称来看,从父亲到子代可以理解为:

ROOT>'a'>'a.b'

也就是说'a.b','a'记录器的propagate设置为False,'a.b'的记录器进行记录时同时会调用'a'记录器和ROOT记录器进行记录,于是就进行了三次记录,同理,

如果'a'记录器的propagate设置为False,'a.b'的记录器进行记录时则不会调用上层记录器,于是只记录一次。

propagate设置可以绝对下层记录器记录时是否调用上层记录器,'a.b'记录器为'a'记录器的下层且所有记录器均为ROOT记录器的下层。

====================================================


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:标准遗传算法(二进制编码 python实现)(遗传算法的编码与解码)
下一篇:查看并添加python中库的搜索路径(查看python库安装路径)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~