ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Python日志封装可多模块调用

2021-11-30 18:31:39  阅读:203  来源: 互联网

标签:__ logging logs Python self message 封装 日志 logger


#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Author: wjh
# @Date  : 2019/06/20 15:00
# @Desc  : 封装log日志文件
 
import logging
import logging.handlers
import os
import time
 
class logs(object):
    def __init__(self,level,logger=None):
        self.logger = logger
        self.logger = logging.getLogger(logger)
        # 设置输出的等级
        LEVELS = {'NOSET':    logging.NOTSET,
                  'DEBUG':    logging.DEBUG,
                  'INFO':     logging.INFO,
                  'WARNING':  logging.WARNING,
                  'ERROR':    logging.ERROR,
                  'CRITICAL': logging.CRITICAL}
        # 创建文件目录
        logs_dir="../log"
        if os.path.exists(logs_dir) and os.path.isdir(logs_dir):
            pass
        else:
            os.mkdir(logs_dir)
        # 修改log保存位置
        timestamp=time.strftime("%Y-%m-%d",time.localtime())
        logfilename= "log-%s.log" % timestamp
        logfilepath=os.path.join(logs_dir,logfilename)
        rotatingFileHandler = logging.handlers.RotatingFileHandler(filename =logfilepath,
                                                                   maxBytes = 1024 * 1024 * 50,
                                                                   backupCount = 500)
        # 设置输出格式
        formatter = logging.Formatter('[%(asctime)s] [%(levelname)s] %(message)s', '%Y-%m-%d %H:%M:%S')
        rotatingFileHandler.setFormatter(formatter)
        # 控制台句柄
        console = logging.StreamHandler()
        Level = LEVELS.get(level)
        console.setLevel(Level)
        console.setFormatter(formatter)
        # 添加内容到日志句柄中
        self.logger.addHandler(rotatingFileHandler)
        self.logger.addHandler(console)
        self.logger.setLevel(Level)
        # 解决重复日志问题
        self.logger.handlers=self.logger.handlers[:1]

    def info(self, message):
        self.logger.info(message)
    def debug(self, message):
        self.logger.debug(message)
    def warning(self, message):
        self.logger.warning(message)
    def error(self, message):
        self.logger.error(message)
if __name__ == '__main__':
    log_ = logs(os.path.basename(__file__).split(".")[0])
    log_.debug('总账本剩余量:{0}'.format(real_balance1))

标签:__,logging,logs,Python,self,message,封装,日志,logger
来源: https://blog.csdn.net/qq_26679243/article/details/121639483

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有