python封装绝对路径的logs方法

该代码定义了一个Logs类,用于在不同模块中调用时,能根据调用模块的路径保存日志。它使用了inspect模块获取调用者文件路径,os模块处理目录,以及logging模块创建流处理器和文件处理器,确保日志在当前目录下生成并按级别记录。
摘要由CSDN通过智能技术生成
可以在其他路径调用该logs方法时,将日志保存在当前日志路径下


import logging
import os
import inspect

LOG_DIR = None


class Logs:

    def getAbsPath(self):
        current_frame = inspect.currentframe()
        caller_frame = inspect.getouterframes(current_frame, 2)[1]
        caller_file = caller_frame.filename
        caller_dir = os.path.dirname(caller_file)
        abs_dir = os.path.abspath(caller_dir)

        os.chdir(abs_dir)
        return os.getcwd()

    def log(self, name="logs", level=logging.DEBUG, sh_level=logging.DEBUG,
            fh_level=logging.DEBUG):
        global LOG_DIR
        if LOG_DIR is None:
            LOG_DIR = self.getAbsPath()

        log_path = os.path.join(LOG_DIR, 'logs.log')
        log = logging.getLogger(name)

        # 2、创建日志收集器的等级
        log.setLevel(level=level)

        # 3、创建日志收集渠道和等级
        sh = logging.StreamHandler()
        sh.setLevel(level=sh_level)
        log.addHandler(sh)
        fh = logging.FileHandler(filename=log_path, encoding="utf-8")
        fh.setLevel(level=fh_level)
        log.addHandler(fh)

        # 4、设置日志的输出格式
        formats = "%(asctime)s - [%(funcName)s-->line:%(lineno)d] - %(levelname)s:%(message)s"
        log_format = logging.Formatter(fmt=formats)
        sh.setFormatter(log_format)
        fh.setFormatter(log_format)
        return log


if __name__ == '__main__':
    log = Logs().log()
    log.info("--------info--------")
    log.error("--------error--------")
    log.warning("--------error--------")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值