ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

内置库 Python logging 高级使用

2022-05-05 11:33:44  阅读:199  来源: 互联网

标签:内置 logging handlers Python DEBUG logger formatter 日志


python日志进阶

学习网站:https://docs.python.org/3/howto/logging.html

组件

  说明

  loggers

  提供应用程序代码直接使用的接口

  handlers   用于将日志记录发送到指定的目的位置
  filters   提供更细粒度的日志过滤功能,用于决定哪些日志记录将会被输出
  formatters   用于控制日志信息的最终输出格式

过滤器和格式器需放在处理器handler里,handler需放在loggers里

处理器可以控制log是输出在控制台还是文件

一个logger可以加多个handler

Logging Flow

 

 log封装

 

#1.使用代码封装
def get_logger(): # create logger 定义记录器 logger = logging.getLogger(os.path.basename(__file__)) logger.setLevel(logging.DEBUG) # create console handler and set level to debug ch = logging.FileHandler(filename='mylog.log', encoding="utf-8") ch.setLevel(logging.DEBUG) # create formatter formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') # add formatter to ch ch.setFormatter(formatter) # add ch to logger logger.addHandler(ch) return logger #引用: logger = get_logger() logger.debug('debug message!') logger.info('info message!') #2.使用logging.conf来封装 [loggers] # loggers 对象列表 keys=root,main [handlers] # handlers 对象列表 keys=consoleHandlers,fileHandlers [formatters] # formatters 列表 keys=fmt [logger_root] level=DEBUG handlers=consoleHandlers,fileHandlers [logger_main] # main logger level = DEBUG handlers = fileHandlers qualname=main propagate=0 [handler_consoleHandlers]# consoleHandlers 指定控制器的输出方向、级别、输出格式、参数 class = StreamHandler level = DEBUG formatter = fmt args = (sys.stdout,) [handler_fileHandlers]]# 循环日志文件 以文件大小来 分割# 每隔 1000 Byte 划分一个日志文件,备份文件为 3 个 class = logging.handlers.RotatingFileHandler level = DEBUG formatter = fmt args = ('./logs/test.log', 'a', 10000, 3, 'UTF-8') #放置log的地方 [formatter_fmt] # fmt 格式 format=%(asctime)s [%(levelname)s] %(message)s (%(filename)s:%(lineno)s) datefmt=

 

#引用:
import logging.config

logging.config.fileConfig("logging.conf")
logger = logging.getLogger("main")
logger.debug("this is debug log!!")

标签:内置,logging,handlers,Python,DEBUG,logger,formatter,日志
来源: https://www.cnblogs.com/manshuoli/p/16224074.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有