1.首先定义你要输出日志的文件夹,我这边定义输出日志的文件夹如下:
2.直接上代码,注意这个代码可以不手动敲,这是官方文档提供的最好最详细代码,直接复制粘贴就可以直接使用
import logging
import os.path
import time
# 进入项目的根目录
root_path = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
# 进入日志文件
log_path = os.path.join(root_path, "log")
# print(log_path)
class Logger:
def __init__(self):
# 定义日志位置和文件名
self.logname = os.path.join(log_path, "{}.log".format(time.strftime("%Y-%m-%d")))
# 定义一个日志容器
self.logger = logging.getLogger("log")
# 设置日志打印的级别
self.logger.setLevel(logging.DEBUG)
# 创建日志输入的格式
self.formater = logging.Formatter(
'[%(asctime)s][%(filename)s %(lineno)d][%(levelname)s]: %(message)s')
# 创建日志处理器,用来存放日志文件
self.filelogger = logging.FileHandler(self.logname, mode='a', encoding="UTF-8")
# 创建日志处理器,在控制台打印
self.console = logging.StreamHandler()
# 设置控制台打印日志界别
self.console.setLevel(logging.DEBUG)
# 文件存放日志级别
self.filelogger.setLevel(logging.DEBUG)
# 文件存放日志格式
self.filelogger.setFormatter(self.formater)
# 控制台打印日志格式
self.console.setFormatter(self.formater)
# 将日志输出渠道添加到日志收集器中
self.logger.addHandler(self.filelogger)
self.logger.addHandler(self.console)
logger = Logger().logger
if __name__ == '__main__':
logger.debug("我打印debug日志")
logger.info("我打印info日志")
logger.warning("我打印warning日志")
logger.error("我打印error日志")
在你自己的代码模块执行这个代码,就会在你的日志文件夹把相关日志打印出来,下面在配一张图,方便你的理解
3.在你需要打印日志得模块,导入loging文件代码包就行,就可以把日志打印在相关得文件了
下面我将举个例子:请看下图