python3 配置logging日志类

时间:2023-03-09 02:54:50
python3 配置logging日志类

配置类config_file:

  

 from configparser import ConfigParser

 class config_file:

     def __init__(self,conf_filePath,encoding="utf-8"):
#打开配置文件,实例化ConfigParser类,并以默认utf-8的编码格式读取文件
self.cf = ConfigParser()
self.cf.read(conf_filePath,encoding) def get_Int_Value(self,section,option):
#获取整数
return self.cf.getint(section,option) def get_boolValue(self,section,option):
#获取布尔值
return self.cf.getboolean(section,option) def get_strValue(self,section,option):
# 获取字符串类型的值
return self.cf.get(section,option) def get_floatValue(self,section,option):
# 获取浮点数值
return self.cf.getfloat(section,option) def get_sections(self):
# 获取所有的section
return self.cf.sections() def get_options(self,section):
# 获取所有的option
return self.cf.options(section)

日志类:

  

 from configparser import ConfigParser
import logging
from config_file import config_file
class Log_Test(config_file):#继承config_file def logging(self):
logger = logging.getLogger(self.get_strValue('log','logger_name')) #从配置文件读取logger名
logger.setLevel(self.get_strValue('log', 'logger_level')) # 设置logger收集器的收集log级别
format_logger = logging.Formatter(self.get_strValue('log','logger_format'))
if(self.get_boolValue('log','logger_out')):
handle = logging.StreamHandler() # 指定输出到console控制台
handle.setLevel(self.get_strValue('log', 'logger_level')) # 读取日志等级并设定logging的级别
handle.setFormatter(format_logger) # 指定日志格式
else:
handle = logging.FileHandler(self.get_strValue('log','logger_filepath'), encoding='utf-8')
handle.setLevel(self.get_strValue('log', 'logger_level')) # 读取日志等级并设定logging的级别
handle.setFormatter(format_logger) # 指定日志格式
logger.addHandler(handle)
return logger

日志配置文件logging.cfg:

  

[log]
#日志收集器
logger_name=TEST
#日志级别 级别需要大写 DEBUG-->INFO-->WARNING-->ERROR-->CRITICAL/FATAL
logger_level=DEBUG
#日志输出格式 注意转义
logger_format=%%(asctime)s-%%(filename)s-%%(levelname)s-日志信息:%%(message)s
#日志是否输出到控制台 True or False
logger_out=False
#日志输出指定文件地址
logger_filepath=logging_Test.log

将读取配置文件类进行封装,日志类继承配置类。