一、在项目中创建log.py文件,内容如下:
import os
import logging
from logging.handlers import TimedRotatingFileHandler
path = os.path.split(os.path.realpath(__file__))[0]
log_path = os.path.join(path, 'result')#存放log文件的路径
class Logger(object):
def __init__(self, logger_name='logs…'):
self.logger = logging.getLogger(logger_name)
logging.root.setLevel(logging.NOTSET)
self.log_file_name = 'test.log'#日志文件的名称
self.backup_count = 5#最多存放日志的数量
# 日志输出级别
self.console_output_level = 'WARNING'
self.file_output_level = 'DEBUG'
# 日志输出格式
self.formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
def get_logger(self):
"""在logger中添加日志句柄并返回,如果logger已有句柄,则直接返回"""
if not self.logger.handlers: # 避免重复日志
console_handler = logging.StreamHandler()
console_handler.setFormatter(self.formatter)
console_handler.setLevel(self.console_output_level)
self.logger.addHandler(console_handler)
# 每天重新创建一个日志文件,最多保留backup_count份
file_handler = TimedRotatingFileHandler(filename=os.path.join(log_path, self.log_file_name), when='D',
interval=1, backupCount=self.backup_count, delay=True, encoding='utf-8')
file_handler.setFormatter(self.formatter)
file_handler.setLevel(self.file_output_level)
self.logger.addHandler(file_handler)
return self.logger
logger = Logger().get_logger()
二、随便新建一个文件或者在自己py文件中引入,我这里随便新建了一个test_logger.py文件。里面随便写了一些内容
import os
import log
path = os.path.split(os.path.realpath(__file__))
file_path = os.path.join(path[0], path[1])
print(path)
print(path[0])
print(path[1])
print(file_path)
logger = log.logger
logger.info('随便打印')#在您的项目中需要打印日志的代码模块,添加logger.info()
三、运行该test_logger.py文件,在项目中的result下生成了一个test.log文件打开查看
小结:在需要输入日志的文件中引入自己的log.py文件,我这里的引入为import log,创建log实例,logger=log.logger。在需要打印日志的代码模块添加logger.info('随便打印')