网站免费搭建wordpress博客分享
目录
- 基础使用
 - 日志的6个级别
 - 打印日志
 - 修改打印级别
 
- 高级应用
 - logging的组成
 - 记录器Loggers
 - 处理器Handlers
 - 过滤器Filter
 - formatter格式
 - 创建关联
 - 打印日志
 
- 配置文件
 - 参考
 
基础使用
日志的6个级别

打印日志
import logginglogging.debug('调试日志')
logging.info('消息日志')
logging.warning('警告日志')
logging.error('错误日志 ')
logging.critical('严重错误日志')
 

注意:默认情况下,logging的输出级别是warning级别
修改打印级别
import logginglogging.basicConfig(level=logging.DEBUG,  format='%(asctime)s %(name)s [%(pathname)s line:%(lineno)d] %(levelname)s %(message)s]', datefmt='%Y-%m-%d %H:%M:%S',   filename='demo.log',filemode='w') 
 
level是指定日志的打印级别
 format是日志输出格式
%(name)s           Logger的名字(get1ogger时指定的名字)
%(levelno)d         数字形式的日志级别
%(levelname)s       文本形式的日志级别
%(pathname)s        调用日志输出位置的完整路径名
%(filename)s        调用日志输出的文件名
%(module)s          调用日志输出日志的模块名
%(funcName)s        调用日志输出日志的函数名
%(1ineno)d          调用日志输出两数的语句所在的代码行
%(created)f         当前时间,用UNIx标准的表示时间的浮 点数表示
%(relativecreated)d 输出日志信息时的,自Loqger创建以 来的毫秒数
%(asctime)s         字符串形式的当前时间,默认格式是“2023-10-05 12:13:33,231”
%(thread)d          线程ID,可能没有
%(threadName)s      线程名,可能没有
%(process)d         进程ID,可能没有
%(message)s         用户输出的消息
 
datefmt是修改 asctime 的时间格式
 filename是若不指定此配置,默认打印在控制台; 指定后,打印到指定路径文件
 filemode是文件写入方式:1.‘w’:覆盖文件中现有数据 2.‘a’ : 追加到文件末尾
高级应用
logging的组成

记录器Loggers
# 实例化一个记录器,并将记录器的名字设为 'training_log'
logger = logging.getLogger(name='training_log')# 设置 logger 的日志级别为 info
logger.setLevel(logging.INFO)
 
如果 logging.getLogger 不设置参数name 的话,默认记录器的名字为 ‘root’
处理器Handlers
# 1、创建一个handler,该handler往console打印输出
console_handler = logging.StreamHandler() 
# 2、设置 console_handler 的日志级别为 debug
console_handler.setLevel(logging.DEBUG) # 3、再创建一个handler,该handler往文件中打印输出
# 未给file_handler指定日志级别,它会默认使用logger 的日志级别 
file_handler = logging.FileHandler(filename='demo.log ') 
 
过滤器Filter
flt = logging.Filter('training.loss')
 
formatter格式
# 创建一个标准版日志打印格式
standard_formatter = logging.setFormatter('%(asctime)s %(name)s [%(pathname)s line:(lineno)d] %(levelname)s %(message)s]')# 创建一个简单版日志打印格式
simple_formatter = logging.setFormatter('%(levelname)s %(message)s]')
 
创建关联
# 让 console_handler 使用 标准版日志打印格式
console_handler.setFormatter(standard_formatter)
# 让 file_handler 使用 标准版日志打印格式
file_handler.setFormatter(simple_formatter)# 给记录器绑定上 console_handler 和 file_handler
logger.addHandler(console_handler)
logger.addHandler(file_handler)#过滤器
logger.addFilter(flt)
 
打印日志
logger.debug('调试日志')
logger.info('消息日志')
logger.warning('警告日志')
logger.error('错误日志 ')
logger.critical('严重错误日志')
 
配置文件

 配置文件log.conf
[loggers]
keys=root, logger01[handlers]
keys=console_handler,file_handler[formatters]
keys=standard_formatter,simple_formatter[logger_root]
level=DEBUG
handlers=file_handler[logger_logger01]
level=INFO
handlers=console_handler
qualname=mylogger
propagate=0[handler_console_handler]
class=StreamHandler
args=(sys.stdout,)
formatter=standard_formatter[handler_file_handler]
level=DEBUG
class=FileHandler
args=("demo.log", 'w')
formatter=simple_formatter[formatter_standard_formatter]
format=%(asctime)s %(name)s [%(pathname)s line:(lineno)d] %(levelname)s %(message)s[formatter_simple_formatter]
format=%(levelname)s %(message)s
 
demo.py
import logging.configlogging.config.fileConfig('demo.conf')root_logger = logging.getLogger()
my_logger = logging.getLogger('mylogger')root_logger.debug('调试日志')
root_logger.info('消息日志')
root_logger.warning('警告日志')
root_logger.error('错误日志 ')
root_logger.critical('严重错误日志')my_logger.debug('调试日志')
my_logger.info('消息日志')
my_logger.warning('警告日志')
my_logger.error('错误日志 ')
my_logger.critical('严重错误日志')
 
参考
参考了b站的Enzo大佬做的笔记,有关例子可见其网站
