一、日志等级
Debug : 打印全部的日志,详细的信息,通常只出现在诊断问题上
Info : 打印info,warning,error,critical级别的日志,确认一切按预期运行
Warning : 打印warning,error,critical级别的日志,一个迹象表明,一些意想不到的事情发生了,或表明一些问题在不久的将来(例如,磁盘空间低),这个软件还能按预期工作
Error : 打印error,critical级别的日志,更严重的问题,软件没能执行一些功能
Critical : 打印critical级别,一个严重的错误,这表明程序本身可能无法继续运行
级别排序:CRITICAL > ERROR > WARNING > INFO > DEBUG
在控制台输出日志
import logging
logging.basicConfig(level=logging.INFO) # 通过basicConfig设置日志级别
logging.debug("这是一条 debug 等级的日志")
logging.info("这是一条 info 等级的日志")
logging.warning("这是一条 warning 等级的日志")
logging.error("这是一条 error 等级的日志")
logging.critical("这是一条 critical 等级的日志")
INFO:root:这是一条 info 等级的日志
WARNING:root:这是一条 warning 等级的日志
ERROR:root:这是一条 error 等级的日志
CRITICAL:root:这是一条 critical 等级的日志
?
运行上述代码,在控制台分别回显了 INFO 、WARNING、ERROR、CRITICAL级别的日志,是因为在日志配置函数basicConfig( ) 中 level = logging.INFO,等级低于 INFO 的 DEBUG 日志不会被记录,而等级等于或高于 INFO 的日志都会被记录
二、logging中常用方法
1、logging.Formatter: 这是一个配置日志格式的类,自定义日志按何种样式记录和展示;
2、logger = logging.getLogger( ): 生成一个logging模块的主体,为程序提供记录日志的接口,并根据日志级别把对应日志分发给不同 handler;
3、logging.FileHandler( ): 把日志记录输出到文件
4、logging.StreamHandler( ): 把日志记录输出出控制台
5、logger.setLevel( ): 设置总的日志级别
6、logger.addHandler( ): 添加一个Handler (FileHandler、StreamHandler)
7、Handler.setLevel( ): 设置handler 的日志级别
8、Handler.setFormatter( ): 设置handler 的输出格式
三、Formatter常用格式:
%(levelno)s: 打印日志级别的数值
%(levelname)s: 打印日志级别名称
%(pathname)s: 打印当前执行程序的路径
%(filename)s: 打印当前执行程序名
%(funcName)s: 打印日志的当前函数
%(lineno)d: 打印日志的当前行号
%(asctime)s: 打印日志的时间
%(thread)d: 打印线程ID
%(threadName)s: 打印线程名称
%(process)d: 打印进程ID
%(message)s: 打印日志信息
四、把日志输出到控制台
import logging
logger = logging.getLogger()
logger.setLevel(logging.INFO)
ch = logging.StreamHandler() # 输出日志到控制台
ch.setLevel(logging.INFO) # 输出到控制台的日志等级
# 定义日志handler的输出格式
fmt = logging.Formatter('%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s')
ch.setFormatter(fmt)
logger.addHandler(ch)
logger.info("这是一个 INFO 日志")
# 2021-06-30 10:29:46,043 - study02.py:[15] - [INFO] - 这是一个 INFO 日志
1、首先通过getLogger( ) 创建一个logging的主体对象logger,供程序调用;
2、通过 setLevel( ) 设置日志总的等级;
3、创建一个Handler对象ch,streamHandler 为输出日志到控制台;
4、为这个Handler实例ch 通过setLevel 设定输出到控制台的日志等级;
5、通过Formatter定义日志的输出格式fmt;
6、通过调用Handler的setFormatter把fmt对象作为参数传入来定义输出到控制台的日志格式;
7、调用logger.addHandler把Handler对象ch添加到logger主体中;
五、把日志输出到文件
import logging
import time
import os
logger = logging.getLogger()
logger.setLevel(logging.INFO)
currTime = time.strftime("%Y-%m-%d")
log_py_path = os.path.abspath(__file__) # 当前py文件的绝对路径,会定位到对应py文件
log_dir_path = os.path.split(log_py_path)[0] # 当前py文件的文件夹路径
pro_path = os.path.dirname(log_dir_path) # 当前py文件对应文件夹的上层目录路径
Log_path = pro_path + '/Logs/'
log_name = Log_path + currTime + '.log'
fh = logging.FileHandler(file_path, mode='a') # mode = 'a' 为在原日志上追加,'w'为覆盖 输出日志到文件
fh.setLevel(logging.INFO) # 输出到 file 的日志等级
# 定义日志handler的输出格式
fmt = logging.Formatter('%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s')
fh.setFormatter(fmt)
logger.addHandler(fh)
logger.info("这是一个 INFO 日志")
?
1、首先通过getLogger( ) 创建一个logging的对象主体logger,供程序调用;
2、通过 setLevel( ) 设置日志总的等级;
3、time.strftime("%Y-%m-%d") 获取当地时间按(年-月-日);
4、os.path.abspath(os.getcwd( )) 获取当前工作目录的绝对路径;
5、创建一个Handler对象fh,FileHandler 为输出日志到文件;
6、为这个Handler对象fh 通过setLevel 设定输出到文件的日志等级;
7、通过Formatter定义日志的输出格式fmt;
8、通过调用Handler的setFormatter把fmt对象作为参数传入来定义输出到控制台的日志格式;
9、调用logger.addHandler把Handler对象ch添加到logger主体中;
封装一个日志类
?
import logging
import time
import os
class Logger:
def __init__(self, name, logger_level='INFO', stream_level='INFO', file_level='INFO'):
# 创建一个 logger
self.__logger = logging.getLogger(name)
# 设置Log等级总开关
self.__logger.setLevel(logger_level)
# 创建 handler,用于日志写入
currTime = time.strftime("%Y-%m-%d-%H") # 获取日期年-月-日-时
log_py_path = os.path.abspath(__file__) # 当前py文件的绝对路径,会定位到对应py文件
log_dir_path = os.path.split(log_py_path)[0] # 当前py文件的文件夹路径
pro_path = os.path.dirname(log_dir_path) # 当前py文件对应文件夹的上层目录路径
Log_path = pro_path + '\\Logs\\'
log_name = Log_path + currTime + '.log'
fh = logging.FileHandler(log_name, mode='a') # mode = 'a' 为在原日志上追加,'w'为覆盖 输出日志到文件
fh.setLevel(file_level) # 输出到 file 的日志等级
ch = logging.StreamHandler() # 输出日志到控制台
ch.setLevel(stream_level) # 输出到控制台的日志等级
# 定义日志handler的输出格式
fmt = logging.Formatter('%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s')
fh.setFormatter(fmt)
ch.setFormatter(fmt)
# 添加 logger 到 handler里面
self.__logger.addHandler(fh)
self.__logger.addHandler(ch)
def get_logger(self):
return self.__logger
?
?