Python - 日志输出不同颜色

3 篇文章 0 订阅
2 篇文章 0 订阅
import logging
import colorlog

log_colors_config = {
    'DEBUG': 'white',
    'INFO': 'green',
    'WARNING': 'yellow',
    'ERROR': 'red',
    'CRITICAL': 'bold_red',
}

logger = logging.getLogger(__name__)


def init_log():
    # 输出到控制台
    console_handler = logging.StreamHandler()
    # 输出到文件
    # file_handler = logging.FileHandler(filename='test.log', mode='a', encoding='utf8')

    # 日志级别,logger 和 handler以最高级别为准,不同handler之间可以不一样,不相互影响
    logger.setLevel(logging.DEBUG)
    console_handler.setLevel(logging.DEBUG)
    # file_handler.setLevel(logging.INFO)

    # 日志输出格式
    log_format = "%(log_color)s[%(asctime)s][%(name)s][%(levelname)s][%(filename)s:%(lineno)d][%(funcName)s] %(message)s"

    # file_formatter = logging.Formatter(
    #     fmt=log_format,  no %(log_color)s
    #     datefmt='%Y-%m-%d  %H:%M:%S'
    # )
    console_formatter = colorlog.ColoredFormatter(
        fmt='{}'.format(log_format),
        log_colors=log_colors_config
    )
    console_handler.setFormatter(console_formatter)
    # file_handler.setFormatter(file_formatter)

    if not logger.handlers:
        logger.addHandler(console_handler)
        # logger.addHandler(file_handler)

    console_handler.close()
    # file_handler.close()

if __name__ == '__main__':
    init_log()
    logger.debug('debug')
    logger.info('info')
    logger.warning('warning')
    logger.error('error')
    logger.critical('critical')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要将 Python logger 的日志信息输出到控制台,可以使用以下步骤: 1. 导入 logging 模块:`import logging` 2. 配置 logger:`logger = logging.getLogger(__name__)` 3. 设置日志级别:`logger.setLevel(logging.INFO)` 4. 创建一个控制台处理器:`console_handler = logging.StreamHandler()` 5. 配置控制台处理器的日志级别:`console_handler.setLevel(logging.INFO)` 6. 创建一个日志格式化器:`formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')` 7. 将格式化器添加到控制台处理器:`console_handler.setFormatter(formatter)` 8. 将控制台处理器添加到 logger:`logger.addHandler(console_handler)` 9. 使用 `logger.info('日志信息')` 输出日志到控制台。 完整示例代码如下: ```python import logging # 配置 logger logger = logging.getLogger(__name__) logger.setLevel(logging.INFO) # 创建一个控制台处理器 console_handler = logging.StreamHandler() console_handler.setLevel(logging.INFO) # 创建一个日志格式化器 formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s') # 将格式化器添加到控制台处理器 console_handler.setFormatter(formatter) # 将控制台处理器添加到 logger logger.addHandler(console_handler) # 输出日志到控制台 logger.info('这是一条日志信息') ``` 运行上述代码后,你将在控制台看到类似以下的输出: ``` 2021-10-15 14:30:00,000 - INFO - 这是一条日志信息 ``` 你可以根据需要调整日志级别和日志格式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

**星光*

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值