当前位置: 首页 > news >正文

训练日志——logging

目录

  • 基础使用
    • 日志的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大佬做的笔记,有关例子可见其网站

http://www.lryc.cn/news/242953.html

相关文章:

  • 尺度为什么是sigma?
  • 迭代器模式
  • C++ 修饰符、存储类、运算符、循环、判断
  • 2023 hnust 湖南科技大学 信息安全管理课程 期中考试 复习资料
  • N皇后问题解的个数
  • php订单发起退款(余额和微信支付)
  • 【SpringCloud】认识微服务、服务拆分以及远程调用
  • Mysql基础操作(命令行)
  • 网站遇到DDOS攻击怎么办?
  • 中间件渗透测试-Server2131(解析+环境)
  • 探究Kafka原理-2.Kafka基本命令实操
  • Linux网卡没有eth0显示ens33原因以及解决办法
  • 1.前端--基本概念【2023.11.25】
  • 计算机视觉面试题-01
  • 108. 将有序数组转换为二叉搜索树 --力扣 --JAVA
  • Springboot实现增删改差
  • 【程序员的自我修养01】编译流程概述
  • 在PyCharm中正确设置Python项目
  • scoop bucket qq脚本分析(qq绿色安装包制作)
  • Elasticsearch:将最大内积引入 Lucene
  • YOLOV7主干改进,使用fasternet轻量化改进主干(完整教程)
  • DALSA.SaperaLT.SapClassBasic无法加载,试图加载格式不正确的程序,c#
  • 设计模式-创建型模式-工厂方法模式
  • 科研/比赛必备工具及系列笔记集合
  • 萨科微举办工作交流和业务分享会
  • 一篇文章让你入门python集合和字典
  • 各种工具的快捷键或命令
  • 【Web】preg_match绕过相关例题wp
  • XSLVGL2.0 User Manual 主题管理器(v2.0)
  • visionOS空间计算实战开发教程Day 2 使用RealityKit显示3D素材