基于python+pytest,是小白的学习之路,过程思路参考EVAN_HU的思路
再写其他模块的时候呢,我发现调试很重要,跑长流程的时候,输出日志是比较直观的方式,我个人认为
import logging
import logging.handlers
import os
from datetime import datetime
from common.read_path import LOGS_PATH
LOGS_FILE_PATH = LOGS_PATH + os.path.sep + datetime.now().strftime("%Y-%m-%d") + "AT_logs.log"
NAME = "root"
class Logger(object):
def __init__(self):
# 创建日志文件
if os.path.exists(LOGS_PATH) is False:
os.makedirs(LOGS_PATH)
# 创建一个logger
self.logger = logging.getLogger(NAME)
self.logger.setLevel(level=logging.DEBUG)
# 每次被调用后,清空已经存在handler
self.logger.handlers.clear()
# 日志格式
self.matter = "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
def logs_file(self):
# 创建一个handler,用于写入日志文件
handle = logging.handlers.TimedRotatingFileHandler(LOGS_FILE_PATH, when='D', encoding='UTF-8')
handle.setLevel(level=logging.DEBUG)
# 生成并设置日志格式
handle.setFormatter(logging.Formatter(self.matter))
self.logger.addHandler(handle)
return self.logger
def logs_cmd(self):
cmd_handle = logging.StreamHandler()
cmd_handle.setLevel(level=logging.DEBUG)
cmd_handle.setFormatter(logging.Formatter(self.matter))
self.logger.addHandler(cmd_handle)
return self.logger
# if __name__ == '__main__':
# Logger().logs_file().debug("aaa")
# Logger().logs_cmd().debug("aaa")
- ?生成的日志文件名称--->2021-08-30AT_logs.log
- ?NAME可以修改,修改成使用者,这样查看日志的时候很好区分
- ?handles.clear() 之前出现了,只执行一次流程,但是每个日志都打印了很多次的情况,所以加上这句话;但是还存在一个问题,就是第一句产生的日志还是重复出现,目前未解决;
? ? ? ?参考文件:https://juejin.cn/post/6844903692915703815? ?中表述创建了自定义的 Logger 对象,就不要在用 logging 中的日志输出方法了,这些方法使用的是默认配置的 Logger 对象,否则会输出的日志信息会重复
自动化所有的文件夹路径我都保存在一个文件中,方便调用
我很菜!请求大家的意见让我成长
|