训练日志——logging

基础使用

日志的6个级别

在这里插入图片描述

打印日志

import logging

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

在这里插入图片描述

注意:默认情况下,logging的输出级别是warning级别

修改打印级别

import logging

logging.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.config

logging.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大佬做的笔记,有关例子可见其网站

  • 11
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

醋酸洋红就是我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值