使用logging模块创建日志

# -*- coding: utf-8 -*-
# author:liucong

import logging
import time
import os
import inspect

from tools.Config import get_basic_config

proj_path = os.path.dirname(inspect.getfile(inspect.currentframe())) + os.path.sep + '..'
log_path = os.path.join(proj_path, 'log')
log_name = os.path.join(log_path, '{0}.txt'.format(time.strftime('%Y-%m-%d')))


def get_logger(name='Web Automation'):
    init_logger = logging.getLogger(name)
    init_logger.setLevel(logging.DEBUG)
    # 格式化模板
    formatter = logging.Formatter(
        fmt='[%(asctime)s][%(levelname)s]<%(name)s> %(message)s',
        datefmt='%H:%M:%S'
    )
    # 流处理器创建与添加
    handler = logging.StreamHandler()
    # 日志是否详细
    detail_flag = get_basic_config('detail_log')
    detail_flag = True if detail_flag == '1' else False
    if detail_flag:
        level = logging.DEBUG
    else:
        level = logging.INFO
    handler.setLevel(level)
    handler.setFormatter(formatter)
    init_logger.addHandler(handler)
    # 日志处理器创建与添加,用于写入日志文件
    # 创建日志目录和日志文件
    os.makedirs(log_path, exist_ok=True)
    if not os.path.exists(log_name):
        log = open(log_name, "a")
        log.close()
    log_handle = logging.FileHandler(log_name, 'a', encoding='utf-8')
    log_handle.setLevel(logging.DEBUG)
    log_handle.setFormatter(formatter)
    init_logger.addHandler(log_handle)
    return init_logger


logger = get_logger()
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Python中,可以使用logging模块来记录日志信息,方便程序员在开发和生产环境中进行调试和问题排查。logging模块提供了全局配置方法,可以通过配置来控制日志的格式、输出方式和级别等。 下面是一个简单的例子,展示如何使用logging模块进行全局配置: ``` import logging # 配置日志格式 formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s') # 创建一个StreamHandler,用于输出到控制台 console_handler = logging.StreamHandler() console_handler.setFormatter(formatter) # 创建一个FileHandler,用于输出到文件 file_handler = logging.FileHandler('example.log') file_handler.setFormatter(formatter) # 创建一个Logger实例 logger = logging.getLogger('example') logger.setLevel(logging.DEBUG) # 将StreamHandler和FileHandler添加到Logger实例中 logger.addHandler(console_handler) logger.addHandler(file_handler) ``` 在上面的例子中,首先创建了一个Formatter对象,用于配置日志的格式。然后,创建了一个StreamHandler和FileHandler,分别用于将日志输出到控制台和文件中。接下来,创建了一个Logger实例,并设置了日志级别为DEBUG。最后,将StreamHandler和FileHandler添加到Logger实例中。 通过全局配置,可以方便地控制日志的输出方式和级别。在程序中,只需要使用logger对象来记录日志即可,例如: ``` logger.debug('debug message') logger.info('info message') logger.warning('warning message') logger.error('error message') logger.critical('critical message') ``` 通过上述配置,日志信息将输出到控制台和文件中,并且可以根据需要调整日志级别。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值