欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 0901python打印异常信息

0901python打印异常信息

2025/4/3 5:56:25 来源:https://blog.csdn.net/qq_37269626/article/details/141773137  浏览:    关键词:0901python打印异常信息

python异常处理

    • 1.目的
    • 2.python异常处理办法
      • 2.1直接打印异常信息
      • 2.2打印异常具体位置
    • 3.日志处理
      • 3.1代码
    • 4.结果输出

1.目的

在java中,我们经常会有统一异常处理以及日志打印模块,同样,python也是,在yolo中很多位置就是用到了这个,比如校验图片的尺寸,后缀名,设备状态等等…

2.python异常处理办法

2.1直接打印异常信息

except中直接print

2.2打印异常具体位置

traceback.print_exec()
在这里插入图片描述

3.日志处理

在这里插入图片描述

3.1代码

"""
@Time    : 2024/9/1 上午8:52
@Author  : chensong
@File    : 1.python异常处理以及日志打印.py
@Desc    : 
"""
import logging
import sys
import traceback
import warningsimport cv2class customerHandler(logging.FileHandler):# mode: a:追加 w:覆盖def __init__(self, filename,mode='a',encoding=None,delay=False):super().__init__(filename,mode,encoding,delay)
#      在此处重写原有方法,比如改变日志记录的格式或者行为def emit(self, record):print('重写了FileHandler类')formatted_record = self.format(record)with open(self.baseFilename,'a') as log_file:log_file.write(formatted_record +'\n')if __name__ == '__main__':# 定义一个logger# 形参为一个str,指定logger名称,不指定则代表是根loggermylogger = logging.getLogger('mylogger')# 设置日志级别,debug属于最低级别日志,所以所有的日志信息都将被打印mylogger.setLevel(logging.DEBUG)# 定义不同的handler可以将日志输出到不同的地方# filehandler,streamhandler,sockethandler,smpthandler# 下方的handler是将日志输出到控制台myHandler = customerHandler('my_logFile.log')formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')myHandler.setFormatter(formatter)mylogger.addHandler(myHandler)mylogger.info('这是自定义的handler处理日志信息')# 2.定义第二个handlerlogger2 = logging.getLogger('secondLogger')streamHandler = logging.StreamHandler()formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')streamHandler.setFormatter(formatter)logger2.addHandler(streamHandler)try:# a = 1/0warnings.warn('a',DeprecationWarning)with warnings.catch_warnings():mylogger.warning('a')cv2.imshow('www')except Exception as e:# 只有error才会到达这里traceback.print_exc()print('开始打印异常原因')# 记录异常及其级别exc_info = sys.exc_info()# 到达这里就会出现错误mylogger.error(exc_info)# 使用完以后移除对应handlermylogger.removeHandler(myHandler)logger2.removeHandler(streamHandler)

4.结果输出

在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词