Python基础之logging模块知识总结
目录
- 前言
- 一、日志级别
- 二、basicConfig
- 三、日志写文件
- 四、traceback记录
前言
logging模块是Python内置的标准模块,主要用于输出脚本运行日志,可以设置输出日志的等级、日志保存路径等。
- 可以通过设置不同的日志等级,在 release 版本中只输出重要信息,而不显示大量的调试信息
- logging 可以决定将信息输出位置和内容
- logging 线程更安全
一、日志级别
级别排序:CRITICAL > ERROR > WARNING > INFO > DEBUG
- debug : 打印全部日志,详细信息,通常只出现在诊断问题
- info : 打印info,warning,error,critical级别的日志,正常输出
- warning : 打印warning,error,critical级别的日志,部分异常,不影响程序
- error : 打印error,critical级别的日志,影响程序部分功能
- critical : 打印critical级别,影响程序运行
import logging # 引入logging模块 # 将信息打印到控制台上 logging.debug("debug") logging.info("info") logging.warning("warning") logging.error("error") logging.critical("critical") [root@zijie ~]# python log.py WARNING:root:warning ERROR:root:error CRITICAL:root:critical
默认生成的root logger的level是logging.WARNING,低于该级别不输出,如果要展示低于WARNING级别的内容,可以引入logging.basicConfig指定日志级别logging.basicConfig(level=logging.DEBUG)
二、basicConfig
import logging logging.basicConfig(level=logging.INFO, format='%(asctime)s %(filename)s %(levelname)s %(message)s', datefmt='%a %d %b %Y %H:%M:%S', filename='xuehui.log', filemode='w') logging.info('This is a info.') logging.debug('This is a debug message.') logging.warning('This is a warning.')
三、日志写文件
import logging import os.path import time #创建logger logger = logging.getLogger() logger.setLevel(logging.DEBUG) # 创建handler,用于写入日志文件 logdate = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())) log_path = 'logs/' log_name = log_path + logdate + '.log' logfile = log_name fh = logging.FileHandler(logfile, mode='w') fh.setLevel(logging.DEBUG) # 定义输出格式 formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s") fh.setFormatter(formatter) # 将logger添加到handler logger.addHandler(fh) # 日志 logger.debug('this is a logger debug message') logger.info('this is a logger info message') logger.warning('this is a logger warning message') logger.error('this is a logger error message') logger.critical('this is a logger critical message')
四、traceback记录
import logging import os.path import time #创建logger logger = logging.getLogger() logger.setLevel(logging.DEBUG) # 创建handler,用于写入日志文件 logdate = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())) log_path = 'logs/' log_name = log_path + logdate + '.log' logfile = log_name fh = logging.FileHandler(logfile, mode='w') fh.setLevel(logging.DEBUG) # 定义输出格式 formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s") fh.setFormatter(formatter) # 将logger添加到handler logger.addHandler(fh) # 日志 try: open('/data/exist', 'rb') except BaseException as e: logger.error('Failed to open file', exc_info=True)
到此这篇关于Python基础之logging模块知识总结的文章就介绍到这了,更多相关Python logging模块内容请搜索hwidc以前的文章或继续浏览下面的相关文章希望大家以后多多支持hwidc!
【出处:潜江网站优化 请说明出处】