当前位置:   article > 正文

【Python实用教学】Python 中如何高效完美地处理日志记录?_python日志记录

python日志记录

img

日志记录在软件开发中扮演着至关重要的角色。它不仅可以帮助开发人员跟踪应用程序的状态和行为,还能提供有价值的诊断信息。Python 提供了内置的 logging 模块,为开发者提供了一个强大且灵活的日志记录工具。

日志的重要性

在软件开发中,对于应用程序的行为进行监控和记录至关重要。日志记录不仅可以在应用程序出现错误时提供关键的调试信息,还能够帮助分析应用程序的性能、用户行为和其他重要数据。

目的和结构

本文将深入探讨 Python 中优雅处理日志的方法。我们将详细介绍 logging 模块的使用,并提供丰富的示例和最佳实践,以帮助开发者规划和实施更完善的日志记录方案。从基础的日志记录到高级的配置,我们将全面覆盖如何使用 Python 处理日志。

1. 基本的日志记录

使用 logging 模块记录日志

Python 的 logging 模块是一个功能强大且灵活的日志记录工具。下面是一个基本的配置和记录日志的示例:

python复制代码import logging

logging.basicConfig(level=logging.DEBUG, filename='app.log', filemode='w',
                    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')

# 创建日志记录器
logger = logging.getLogger('my_app')

# 记录日志
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')
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

以上示例演示了如何设置全局的日志级别、日志文件和格式化,并记录不同级别的日志信息。

2. 高级日志配置

格式化和处理器

日志格式化和处理器对于记录清晰和可读的日志非常重要。下面展示如何使用不同的格式和处理器记录日志信息:

python复制代码formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')

console_handler = logging.StreamHandler()
console_handler.setFormatter(formatter)
logger.addHandler(console_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')
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

以上示例展示了如何自定义日志格式并使用不同的处理器,将日志消息输出到不同的目标(例如控制台)。

3. 高级日志配置

日志记录器配置文件

使用配置文件管理日志记录器配置是一种更为清晰和易于维护的方式。以下是一个示例,展示如何通过配置文件设置日志记录器:

python复制代码import logging.config

logging.config.fileConfig('logging.conf')

logger = logging.getLogger('my_app')
  • 1
  • 2
  • 3
  • 4
  • 5

logging.conf 文件内容示例:

conf复制代码[loggers]
keys=root,my_app

[logger_my_app]
level=DEBUG
handlers=consoleHandler

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

[formatter_basicFormatter]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
datefmt=
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

配置文件定义了日志记录器的级别、处理器和格式化信息,使得配置更加集中和易于修改。

日志记录的过滤器

日志过滤器可以根据特定的条件来过滤和记录日志信息。以下是一个过滤器的简单示例:

python复制代码class InfoFilter(logging.Filter):
    def filter(self, record):
        return record.levelno == logging.INFO

console_handler.addFilter(InfoFilter())
  • 1
  • 2
  • 3
  • 4
  • 5

在这个示例中,过滤器只会记录级别为 INFO 的日志信息到控制台处理器。

日志旋转

日志旋转是管理日志文件大小和数量的重要工具。下面是一个日志旋转的示例:

python复制代码from logging.handlers import RotatingFileHandler

handler = RotatingFileHandler('app.log', maxBytes=10000, backupCount=5)
logger.addHandler(handler)
  • 1
  • 2
  • 3
  • 4

此示例展示了如何配置日志旋转,使得日志文件能够按文件大小进行切割,并保留一定数量的备份文件。

总结

优雅地处理日志对于应用程序的健康运行至关重要。logging 模块为开发者提供了多种方法来记录和管理日志信息。从基础的配置到高级的处理器和过滤器,在本文中全面探讨了 Python 中如何优雅地处理日志。


以上就是今天的全部内容分享,觉得有用的话欢迎点赞收藏哦!

Python经验分享

学好 Python 不论是用于就业还是做副业赚钱都不错,而且学好Python还能契合未来发展趋势——人工智能、机器学习、深度学习等。
小编是一名Python开发工程师,自己整理了一套最新的Python系统学习教程,包括从基础的python脚本到web开发、爬虫、数据分析、数据可视化、机器学习等。如果你也喜欢编程,想通过学习Python转行、做副业或者提升工作效率,这份【最新全套Python学习资料】 一定对你有用!

小编为对Python感兴趣的小伙伴准备了以下籽料 !

对于0基础小白入门:

如果你是零基础小白,想快速入门Python是可以考虑培训的!

  • 学习时间相对较短,学习内容更全面更集中
  • 可以找到适合自己的学习方案

包括:Python激活码+安装包、Python web开发,Python爬虫,Python数据分析,人工智能、机器学习、Python量化交易等学习教程。带你从零基础系统性的学好Python!

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。


最新全套【Python入门到进阶资料 & 实战源码 &安装工具】(安全链接,放心点击)

我已经上传至CSDN官方,如果需要可以扫描下方官方二维码免费获取【保证100%免费】

*今天的分享就到这里,喜欢且对你有所帮助的话,记得点赞关注哦~下回见 !

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/810458
推荐阅读
相关标签
  

闽ICP备14008679号