Python日志输出:从入门到实践,让你的代码更好的显示日志信息

在进行Python编程时,为了更好地了解程序的运行情况,调试及错误排查,我们需要使用日志来记录程序运行过程中的信息。Python提供了标准库logging,可以很方便地输出日志信息,本文将对Python日志输出进行详细阐述,从入门到实践,教你如何让你的代码更好地显示日志信息。

一、Python日志输出基础

Python的logging模块提供了日志记录的功能。它可以输出到终端、文件、邮件等,可读性较高,同时可以更灵活地进行管理和控制。下面是一个简单的例子:

“`
import logging

logging.basicConfig(level=logging.DEBUG)
logging.debug(‘This is a debug message’)
logging.info(‘This is an info message’)
logging.warning(‘This is a warning message’)
logging.error(‘This is an error message’)
logging.critical(‘This is a critical message’)
“`

运行上述代码,会依次输出不同级别的日志信息:

“`
DEBUG:root:This is a debug message
INFO:root:This is an info message
WARNING:root:This is a warning message
ERROR:root:This is an error message
CRITICAL:root:This is a critical message
“`

上述代码中,我们使用logging.basicConfig()配置了日志的基本信息。level=logging.DEBUG表示将日志等级设置为DEBUG,即输出该等级及以上等级的日志信息。除了DEBUG等级,还有INFO、WARNING、ERROR、CRITICAL等级。接着,我们使用logging.debug()、logging.info()等方法输出不同等级的日志信息。

另外,我们还可以通过设置format参数来控制输出的格式,比如:

“`
import logging

logging.basicConfig(level=logging.DEBUG, format=’%(asctime)s – %(name)s – %(levelname)s – %(message)s’)
logger = logging.getLogger(__name__)
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’)
“`

运行上述代码,会按照设置的格式输出日志信息:

“`
2021-08-10 11:11:26,537 – __main__ – DEBUG – This is a debug message
2021-08-10 11:11:26,538 – __main__ – INFO – This is an info message
2021-08-10 11:11:26,538 – __main__ – WARNING – This is a warning message
2021-08-10 11:11:26,538 – __main__ – ERROR – This is an error message
2021-08-10 11:11:26,538 – __main__ – CRITICAL – This is a critical message
“`

在上述代码中,我们设置format参数为’%(asctime)s – %(name)s – %(levelname)s – %(message)s’,其中’%(asctime)s’表示输出时间,’%(name)s’表示输出日志所在模块的名称,’%(levelname)s’表示日志等级,’%(message)s’表示输出日志信息。

二、Python日志输出高级配置

1. 使用配置文件进行配置

基本配置虽然简单易懂,但灵活性不够,无法满足复杂的需求。此时我们可以使用配置文件进行配置。下面是一个配置文件的例子:

“`
[loggers]
keys=root,sampleLogger

[handlers]
keys=consoleHandler,fileHandler

[formatters]
keys=sampleFormatter

[logger_root]
level=DEBUG
handlers=consoleHandler,fileHandler

[logger_sampleLogger]
level=DEBUG
handlers=consoleHandler
qualname=sampleLogger
propagate=0

[handler_consoleHandler]
class=StreamHandler
level=DEBUG
formatter=sampleFormatter
args=(sys.stdout,)

[handler_fileHandler]
class=FileHandler
level=DEBUG
formatter=sampleFormatter
args=(‘example.log’, ‘w’)

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

上述配置文件中,我们定义了三个部分:loggers、handlers、formatters。loggers定义了所有日志器的名称;handlers定义了所有处理器的名称和类型;formatters定义了所有格式化器的名称、格式化字符串和输出日期格式。接着,我们定义了日志器们和它们的属性:level表示日志的等级;handlers表示对应的处理器;qualname表示日志器的名称;propagate表示是否向上传递该日志消息。最后,我们定义了两个处理器和一个格式化器。

使用配置文件的方式可以使日志的配置更加灵活,也更方便进行维护。使用方法如下:

“`
import logging.config

logging.config.fileConfig(‘logging.conf’)
logger = logging.getLogger(‘sampleLogger’)
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’)
“`

运行上述代码,会按照配置文件中定义的属性输出日志信息。而对于项目较大的情况,在一个文件中定义格式化内容,并对多个模块使用不同等级会更加便利。

2. 使用RotatingFileHandler进行日志回滚

另一个常用的配置是日志回滚。日志文件占用空间过大时,我们可以通过日志回滚将旧的日志文件进行删除或压缩。Python中提供了RotatingFileHandler来优雅地进行日志回滚。下面是一个例子:

“`
import logging
from logging.handlers import RotatingFileHandler

logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG)
formatter = logging.Formatter(‘%(asctime)s – %(name)s – %(levelname)s – %(message)s’)

# 每个日志文件最大的大小
maxBytes = 1024
# 最多保留的日志文件数量
backupCount = 3

# 添加RotatingFileHandler
file_handler = RotatingFileHandler(‘example.log’, mode=’a’, maxBytes=maxBytes, backupCount=backupCount, encoding=None, delay=0)
file_handler.setFormatter(formatter)
file_handler.setLevel(logging.DEBUG)
logger.addHandler(file_handler)

# 输出日志信息
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’)
“`

在上述代码中,我们首先创建一个日志器和formatter,并定义了日志的等级和输出格式。接着我们使用RotatingFileHandler创建文件处理器,并设置最大的日志文件大小为1024字节,并最多保留3个日志文件。最后,我们将处理器加入到日志器中,并使用日志器输出日志信息。

三、Python日志常用技巧

1. 输出调用位置

在日志输出中,有时需要输出日志消息所在的源代码行数、函数名和模块名等调用位置信息,这时可以使用logging模块提供的LogRecord属性。下面是一个例子:

“`
import logging

logging.basicConfig(level=logging.DEBUG, format=’%(asctime)s – %(name)s – %(levelname)s – %(message)s – %(pathname)s:%(lineno)d’)
logger = logging.getLogger(__name__)
logger.debug(‘This is a debug message’)
“`

在上述代码中,我们使用format参数设置了输出日志的格式,并添加了LogRecord属性pathname、lineno,分别表示源代码文件名和所在行号。运行上述代码,输出日志消息以及调用位置信息。

2. 分模块输出日志

在编程中,我们经常会使用多个模块协同工作,为了更好地了解各个模块的日志信息,我们可以为每个模块都创建一个日志器,使用不同的日志输出方式和等级。例如:

“`
# main.py
import logging
import module1
import module2

logging.basicConfig(level=logging.DEBUG, format=’%(asctime)s – %(name)s – %(levelname)s – %(message)s’)

logger1 = logging.getLogger(‘module1’)
logger2 = logging.getLogger(‘module2’)

logger1.setLevel(logging.DEBUG)
logger2.setLevel(logging.WARNING)

stream_handler = logging.StreamHandler()
stream_handler.setFormatter(logging.Formatter(‘%(asctime)s – %(name)s – %(levelname)s – %(message)s’))
logger1.addHandler(stream_handler)

file_handler = logging.FileHandler(‘module2.log’)
file_handler.setFormatter(logging.Formatter(‘%(asctime)s – %(name)s – %(name)s – %(levelname)s – %(message)s’))
logger2.addHandler(file_handler)

logger1.debug(‘debug message in module1’)
module1.func1()

logger2.warning(‘warning message in module2’)
module2.func2()
“`

在上述代码中,我们在main.py中定义两个日志器logger1和logger2,并设置它们的不同等级和输出方式。我们将’example.log’文件设为logger2的输出文件,并添加输出格式。

然后我们在module1.py和module2.py文件中定义了func1()和func2()函数,并分别输出日志信息。我们通过这种方式,可以为各个模块设置不同的日志等级和输出方式,方便我们进行错误排查与修复。

结语

Python提供了强大的logging模块,方便我们输出日志信息。我们可以通过logging模块的基本使用、高级配置、常用技巧等多个方面,实现更为灵活、高效的日志记录。希望本文能对你在Python的编程工程中带来帮助。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/277332.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-19 13:20
下一篇 2024-12-19 13:20

相关推荐

  • Python官网中文版:解决你的编程问题

    Python是一种高级编程语言,它可以用于Web开发、科学计算、人工智能等领域。Python官网中文版提供了全面的资源和教程,可以帮助你入门学习和进一步提高编程技能。 一、Pyth…

    编程 2025-04-29
  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • Python字符串宽度不限制怎么打代码

    本文将为大家详细介绍Python字符串宽度不限制时如何打代码的几个方面。 一、保持代码风格的统一 在Python字符串宽度不限制的情况下,我们可以写出很长很长的一行代码。但是,为了…

    编程 2025-04-29
  • Python wordcloud入门指南

    如何在Python中使用wordcloud库生成文字云? 一、安装和导入wordcloud库 在使用wordcloud前,需要保证库已经安装并导入: !pip install wo…

    编程 2025-04-29
  • Python基础代码用法介绍

    本文将从多个方面对Python基础代码进行解析和详细阐述,力求让读者深刻理解Python基础代码。通过本文的学习,相信大家对Python的学习和应用会更加轻松和高效。 一、变量和数…

    编程 2025-04-29
  • Python小波分解入门指南

    本文将介绍Python小波分解的概念、基本原理和实现方法,帮助初学者掌握相关技能。 一、小波变换概述 小波分解是一种广泛应用于数字信号处理和图像处理的方法,可以将信号分解成多个具有…

    编程 2025-04-29
  • 掌握magic-api item.import,为你的项目注入灵魂

    你是否曾经想要导入一个模块,但却不知道如何实现?又或者,你是否在使用magic-api时遇到了无法导入的问题?那么,你来到了正确的地方。在本文中,我们将详细阐述magic-api的…

    编程 2025-04-29
  • Python满天星代码:让编程变得更加简单

    本文将从多个方面详细阐述Python满天星代码,为大家介绍它的优点以及如何在编程中使用。无论是刚刚接触编程还是资深程序员,都能从中获得一定的收获。 一、简介 Python满天星代码…

    编程 2025-04-29
  • 仓库管理系统代码设计Python

    这篇文章将详细探讨如何设计一个基于Python的仓库管理系统。 一、基本需求 在着手设计之前,我们首先需要确定仓库管理系统的基本需求。 我们可以将需求分为以下几个方面: 1、库存管…

    编程 2025-04-29
  • 写代码新手教程

    本文将从语言选择、学习方法、编码规范以及常见问题解答等多个方面,为编程新手提供实用、简明的教程。 一、语言选择 作为编程新手,选择一门编程语言是很关键的一步。以下是几个有代表性的编…

    编程 2025-04-29

发表回复

登录后才能评论