python logging日志根据等级适配颜色

本文展示了如何在Python中使用colorlog模块来增强日志输出,通过设置不同级别的颜色,如DEBUG、INFO、WARNING、ERROR和CRITICAL。示例代码包括直接导入和使用ColoredFormatter以及使用dictConfig配置日志,以实现彩色的控制台日志显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装模块:pip install colorlog

代码参考如下:设置下formatter即可

import logging
from colorlog import ColoredFormatter


formatter = ColoredFormatter(
    # log_color设置颜色,如果使用reset,则后续颜色不改变,可使用第八行配置运行下看下效果
    "%(log_color)s%(levelname)s %(asctime)s %(module)s:%(lineno)d %(message)s",
    # "%(log_color)s%(levelname)-8s%(reset)s %(log_color)s%(message)s",
    datefmt=None,
    reset=True,
    #设置不同等级颜色
    log_colors={
        'DEBUG':    'fg_thin_cyan',
        'INFO':     'thin_green',
        'WARNING':  'yellow',
        'ERROR':    'red',
        'CRITICAL': 'red',
    },
    secondary_log_colors={},
    style='%'
)

handler = logging.StreamHandler()
handler.setFormatter(formatter)

logger=logging.getLogger('test')
logger.setLevel(logging.DEBUG)
logger.addHandler(handler)

logger.debug('debug')
logger.info('info')
logger.warning('waring')
logger.error('error')
logger.critical('critical')

dictconfig配置参考如下:

import os
import time
import logging
from logging import config
from logging import Filter

# 日志配置
LOGGING = {
    # 使用的python内置的logging模块,那么python可能会对它进行升级,所以需要写一个版本号,目前就是1版本
    'version': 1,
    # 是否去掉目前项目中其他地方中以及使用的日志功能,但是将来我们可能会引入第三方的模块,里面可能内置了日志功能,所以尽量不要关闭,肯定False
    'disable_existing_loggers': False,
    # 日志的处理格式
    'formatters': {
        # 详细格式,往往用于记录日志到文件/其他第三方存储设备
        'verbose': {
            # levelname等级,asctime记录时间,module表示日志发生的文件名称,lineno行号,message错误信息
            'format': '{levelname} {asctime} {module}:{lineno:d} {message}',
            # 日志格式中的,变量分隔符
            'style': '{',
        },
        'simple': {  # 简单格式,往往用于终端
            'format': '{levelname} {module}:{lineno} {message}',
            'style': '{',
        },
        'colored': {
            '()': 'colorlog.ColoredFormatter',
            'format': "%(log_color)s%(levelname)s %(message)s",
            'log_colors':{
                'DEBUG':    'cyan',
                'INFO':     'green',
                'WARNING':  'yellow',
                'ERROR':    'red',
                'CRITICAL': 'red,bg_white',
            },
        }
    },
    'filters': { # 日志的过滤设置,可以对日志进行输出时的过滤用的
        # 在debug=True下产生的一些日志信息,要不要记录日志,需要的话就在handlers中加上这个过滤器,不需要就不加
        'require_debug_true': {
            '()': Filter,
        },
    },
    'handlers': {  # 日志的处理方式
        'console': {  # 终端下显示
            'level': 'DEBUG',  # 日志的最低等级
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler', # 处理日志的核心类
            'formatter': 'simple'
        },
        'color':{  # 终端下显示
            'level': 'DEBUG',  # 日志的最低等级
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler', # 处理日志的核心类
            'formatter': 'colored'
        },
        'file': {  # 文件中记录日志
            'level': 'INFO',
            'class': 'logging.handlers.TimedRotatingFileHandler',
            # 日志位置,日志文件名,日志保存目录必须手动创建
            'filename': os.path.join(os.path.abspath(os.path.dirname(__file__)),time.strftime("%Y-%m-%d", time.gmtime()) + '.log'),
            # 备份日志文件的数量,设置最大日志数量为10
            'backupCount': 10,
            # 日志格式:详细格式
            'formatter': 'verbose',
            # 设置默认编码,否则打印出来汉字乱码
            'encoding': 'utf-8',
            'when':'midnight'
        },
    },
    # 日志实例对象
    'loggers': {
        'chunda': {
            'handlers': ['color', 'file'],
            'propagate': True,  # 是否让日志信息继续冒泡给其他的日志处理系统
            'level': 'DEBUG'
        }
    }
}

config.dictConfig(LOGGING)

logger=logging.getLogger('chunda')

logger.info('info')
logger.debug('debug')
logger.warning('warning')
<think>好的,我现在需要详细解释Pythonlogging模块的日志级别。首先,用户已经提供了四个相关的引用内容,我需要结合这些信息来组织回答。 首先,根据引用1和引用2,日志级别分为五个:DEBUG、INFO、WARNING、ERROR、CRITICAL。需要说明每个级别的用途和适用场景。例如,DEBUG用于调试,INFO用于记录常规操作,WARNING表示警告,ERROR是错误,CRITICAL是严重问题。 接下来,引用4提到在开发阶段使用DEBUG级别,稳定后可能调整为INFO或更高级别,同时强调在关键操作如涉及金钱交易时需要记录INFO及以上级别。异常处理建议使用ERROR级别。这部分需要详细说明每个级别的适用情况,以及如何根据项目阶段调整日志级别。 然后,需要解释如何设置日志级别。根据引用1和2中的例子,可以通过logging.basicConfig来配置,或者在代码中直接设置logger的级别,比如logger.setLevel(logging.DEBUG)。同时,提到不同模块可以有不同的日志级别,比如引用3中的例子,Django中使用getLogger('mylogger')来定义特定的logger,并设置其级别。 还需要注意用户提到的疑问:在系统稳定后是否应该删除DEBUG语句。根据引用4中的观点,建议保留DEBUG语句,以便维护时使用,但通过调整日志级别来避免输出过多信息。这需要在回答中强调,正确的做法是调整级别而不是删除代码。 最后,生成相关问题时要围绕日志级别展开,可能涉及如何配置、实际应用中的注意事项、与其他模块整合(如Django)、性能影响等。例如,如何根据环境切换日志级别,如何在Django中配置日志日志级别对程序性能的影响等。 需要确保回答结构清晰,分点解释每个日志级别,并给出配置示例,比如代码块展示设置不同级别的例子。同时,引用对应的引用来源,比如引用1和2中的代码示例,引用4中的建议。 现在需要检查是否有遗漏的信息,比如是否提到默认的日志级别是WARNING,这点在引用1和2的示例中,默认情况下只有WARNING及以上级别会被记录,因此需要明确指出。此外,还要说明日志级别的数值表示,比如DEBUG=10,INFO=20等,但用户可能更关注实际应用而非内部数值。 总结回答结构:先介绍五个级别及其用途,然后说明如何设置级别,接着讨论在不同阶段如何选择级别,最后给出配置示例。相关问题部分则围绕配置、优化、应用场景等展开。</think>### Pythonlogging模块的日志级别详解 Python的`logging`模块定义了5个标准日志级别,按严重程度从低到高排列如下: 1. **DEBUG** 用于记录详细的调试信息,通常在开发阶段使用。例如: ```python logging.debug("变量x的值为: %s", x) ``` 2. **INFO** 记录程序运行中的常规操作,如用户登录、数据更新等。例如: ```python logging.info("用户%s成功登录", username) ``` 3. **WARNING** 表示潜在的问题,但程序仍可正常运行。例如磁盘空间不足: ```python logging.warning("磁盘剩余空间仅剩10%") ``` 4. **ERROR** 记录程序运行中的错误(如异常捕获),但程序可能部分功能失效。例如: ```python try: risky_operation() except Exception as e: logging.error("操作失败: %s", e) ``` 5. **CRITICAL** 表示严重错误,可能导致程序崩溃。例如数据库连接丢失: ```python logging.critical("数据库连接中断,服务不可用") ``` --- ### 关键特性与配置 1. **默认日志级别** 默认只记录`WARNING`及以上级别,可通过以下方式修改: ```python logging.basicConfig(level=logging.DEBUG) # 启用所有级别 ``` 2. **级别数值映射** 每个级别对应一个整数值: $$ \text{DEBUG}=10,\ \text{INFO}=20,\ \text{WARNING}=30,\ \text{ERROR}=40,\ \text{CRITICAL}=50 $$ 3. **环境适配建议** - **开发阶段**:使用`DEBUG`级别,便于追踪问题[^4]。 - **生产环境**:调整为`INFO`或`WARNING`,减少日志量并关注核心操作(如支付记录)[^4]。 - **异常处理**:始终用`ERROR`记录异常,避免遗漏关键错误[^4]。 4. **模块化配置示例** Django项目中可为不同组件设置独立日志器: ```python # views.py logger = logging.getLogger('mylogger') logger.setLevel(logging.INFO) # 此日志器仅记录INFO及以上级别[^3] ``` --- ### 常见问题解答 **Q:是否应在生产环境删除DEBUG日志语句?** 不建议删除,可通过调整日志级别控制输出。保留DEBUG语句便于后续维护时快速启用调试[^4]。 **Q:如何按环境切换日志级别?** 可通过配置文件动态设置,例如: ```python import os environment = os.getenv("ENV", "dev") level = logging.DEBUG if environment == "dev" else logging.INFO logging.basicConfig(level=level) ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值