python中logging模块

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
@author:     白清羽
@contact:    https://blog.csdn.net/gufenchen
@others:     All by BaiQingYu, All rights reserved-- Created on 2019/5/15
@desc:       
"""
import datetime
import logging
import os
import sys
import time
from logging.handlers import RotatingFileHandler
try:
    iteration_time = os.environ['WEBSERVICE_ITERATION_RUN_TIME']
except KeyError:
    iteration_time = time.strftime("%Y-%m-%d_%H_%M_%S")

# 如果去掉下面这一句,生成的日志就和testcase处于同一个文件夹下面
ROOT_DIR = os.path.abspath(os.path.curdir)

ROOT_DIR = os.path.dirname(ROOT_DIR)

# sys.path.append(ROOT_DIR)
logFile = os.path.join(ROOT_DIR, 'logs')
logFile = os.path.join(logFile, iteration_time)
logLevel = 3   # 1:notset 2:debug  3:info 4:warning 5:error 6:critical

_logLevel = {
    1: logging.NOTSET,
    2: logging.DEBUG,
    3: logging.INFO,
    4: logging.WARNING,
    5: logging.ERROR,
    6: logging.CRITICAL
}

# loggers = {}


def get_logger():
    """    定义2个log handler: RotatingFileHandler and StreamHandler。logLevel 取自配置文件
    :return:
    """
    # global loggers
    funcName = sys._getframe().f_back.f_code.co_filename
    script_name = funcName.split(os.sep)[-1].split('.')[0]

    log_level = logLevel
    log_path = logFile
    if os.path.exists(log_path):
        log_file = os.path.join(log_path, script_name + '.log')
    else:
        os.makedirs(r'%s' % log_path)
        log_file = os.path.join(log_path, script_name + '.log')

    logger = logging.getLogger()    # RootLogger
    logger.setLevel(_logLevel[log_level])
    if not logger.handlers:
        # 1.1 一个handler,用于写入日志文件,每次运行都会产生一个新的日志文件
        # fh = logging.FileHandler(log_file)
        # fh.setLevel(_logLevel[log_level])

        # 1.2 再创建一个handler,用于输出到控制台
        ch = logging.StreamHandler()
        # ch.setLevel(logging.ERROR)  # 只有错误信息才会在控制台输出
        ch.setLevel(_logLevel[log_level])

        # 1.3 定义一个RotatingFileHandler,最多备份5个日志文件,每个日志文件最大10M
        # # rh和fh 不要使用
        # rh = RotatingFileHandler(log_file, maxBytes=10 * 1024 * 1024, backupCount=5)

        rh = RotatingFileHandler(log_file, maxBytes=10 * 1024 * 1024, backupCount=5, encoding='utf-8')
        rh.setLevel(_logLevel[log_level])

        # 2 定义handler的输出格式
        # formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s')
        formatter = logging.Formatter('%(asctime)s [%(filename)s][line:%(lineno)d][%(name)s][%(levelname)s] %(message)s')
        # fh.setFormatter(formatter)
        ch.setFormatter(formatter)
        rh.setFormatter(formatter)

        # 3 给RootLogger添加handler
        # logger.addHandler(fh)
        logger.addHandler(ch)
        logger.addHandler(rh)
        # loggers.update(dict(name=logger))
    return logger

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值