linux

Linux如何配置Python的日志系统

小樊
35
2025-09-16 13:22:19
栏目: 编程语言

在Linux系统中配置Python的日志系统,可以通过多种方式实现,包括使用Python的内置logging模块、配置文件(如INI、JSON、YAML格式)以及第三方库。以下是一些常见的配置方法:

使用Python内置的logging模块

Python的logging模块提供了灵活的日志记录功能。可以通过编程方式配置日志系统,也可以使用配置文件。

编程方式配置

import logging

# 创建一个logger
logger = logging.getLogger('my_logger')
logger.setLevel(logging.DEBUG)

# 创建handlers
c_handler = logging.StreamHandler()
c_handler.setLevel(logging.INFO)

f_handler = logging.FileHandler('my_app.log')
f_handler.setLevel(logging.ERROR)

# 创建formatters并添加到handlers
c_format = logging.Formatter('%(name)s - %(levelname)s - %(message)s')
c_handler.setFormatter(c_format)

f_format = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
f_handler.setFormatter(f_format)

# 将handlers添加到logger
logger.addHandler(c_handler)
logger.addHandler(f_handler)

# 使用logger
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

使用配置文件配置

可以使用logging.config.fileConfig()函数从INI文件加载配置。

logging.ini

[loggers]
keys=root,my_logger

[handlers]
keys=consoleHandler,fileHandler

[formatters]
keys=simpleFormatter, detailedFormatter

[logger_root]
level=DEBUG
handlers=consoleHandler

[logger_my_logger]
level=DEBUG
handlers=consoleHandler,fileHandler
qualname=my_logger
propagate=0

[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=simpleFormatter
args=(sys.stdout,)

[handler_fileHandler]
class=FileHandler
level=ERROR
formatter=detailedFormatter
args=('my_app.log', 'a')

[formatter_simpleFormatter]
format=%(name)s - %(levelname)s - %(message)s
datefmt=

[formatter_detailedFormatter]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
datefmt=%Y-%m-%d %H:%M:%S

Python代码

import logging
import logging.config

# 加载配置文件
logging.config.fileConfig('logging.ini')

# 获取logger实例
logger = logging.getLogger('my_logger')

# 使用logger
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

使用第三方库

还有一些第三方库可以帮助配置Python的日志系统,例如loguru

使用loguru

from loguru import logger

# 配置日志
logger.add("my_app.log", level="ERROR", format="{time} {level} {message}")

# 使用logger
logger.debug('This is a debug message')  # 不会记录,因为级别低于ERROR
logger.info('This is an info message')   # 不会记录,因为级别低于ERROR
logger.warning('This is a warning message')  # 不会记录,因为级别低于ERROR
logger.error('This is an error message')  # 会记录
logger.critical('This is a critical message')  # 会记录

总结

选择哪种方法取决于具体的需求和项目的复杂性。

0
看了该问题的人还看了