Python实战:深入浅出应用logging模块轻松实现项目日志记录
off999 2024-12-25 14:47 37 浏览 0 评论
引言
在项目开发过程中,日志记录是不可或缺的一部分。它可以帮助开发者追踪代码执行过程、排查问题、监控系统运行状态以及进行性能分析等。Python内置的logging模块提供了全面的日志处理功能,从简单的打印输出到复杂多级的日志管理都能胜任。本文将深入浅出地介绍如何使用Python的logging模块来实现项目的日志记录,并通过实际代码示例展示其用法。
一、logging模块基础概念
- Logger(日志器): 是日志记录的主要对象,用于创建和分发日志事件。
- Handler(处理器): 负责将日志消息格式化并发送到适当的目的地,如控制台、文件、邮件等。
- Formatter(格式器): 定义了日志消息的输出格式,包括时间戳、日志级别、日志信息等内容。
- Level(级别): 日志级别分为DEBUG、INFO、WARNING、ERROR、CRITICAL五个等级,分别对应不同的严重程度。
二、logging模块的基本使用
下面是一个基本的日志配置与使用的示例:
import logging
# 创建一个logger实例
logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG) # 设置日志级别
# 创建一个StreamHandler,用于向控制台输出日志
handler = logging.StreamHandler()
handler.setLevel(logging.DEBUG) # 设置处理器的日志级别,确保不会过滤掉日志器级别的日志
# 创建一个Formatter实例,定义日志输出格式
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
# 将处理器添加到logger中
logger.addHandler(handler)
# 使用logger记录不同级别的日志
logger.debug("调试信息")
logger.info("常规操作信息")
logger.warning("警告信息")
logger.error("错误信息")
logger.critical("严重错误信息")
三、为不同日志设置不同的处理器
在大型项目中,我们可能需要将不同级别的日志输出到不同的地方,比如DEBUG和INFO级别的日志输出到控制台,ERROR及以上的日志写入文件:
import logging
from logging.handlers import RotatingFileHandler
# 获取名为'app_logger'的logger
app_logger = logging.getLogger('app_logger')
app_logger.setLevel(logging.DEBUG)
# 控制台日志处理器
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)
console_formatter = logging.Formatter('%(levelname)s: %(message)s')
console_handler.setFormatter(console_formatter)
app_logger.addHandler(console_handler)
# 文件日志处理器
file_handler = RotatingFileHandler('application.log', maxBytes=10*1024*1024, backupCount=5) # 每个文件最大10MB,最多备份5份
file_handler.setLevel(logging.ERROR)
file_formatter = logging.Formatter('%(asctime)s — %(name)s — %(levelname)s — %(message)s')
file_handler.setFormatter(file_formatter)
app_logger.addHandler(file_handler)
# 记录日志
app_logger.debug("调试日志")
app_logger.info("正常操作日志")
app_logger.warning("警告日志")
app_logger.error("错误日志")四、总结与注意事项
- 在实际应用中,建议在项目初始化阶段集中配置日志系统。
- 根据需求合理设置日志级别,避免过多无用日志影响性能或遗漏重要信息。
- 可以根据项目规模和复杂度灵活调整日志策略,例如采用自定义Handler或者Filter实现更复杂的日志处理逻辑。
通过上述示例,相信你已经掌握了Python logging模块的基础使用方法,将其运用到自己的项目中可以显著提升软件的可维护性和稳定性。希望这篇博客能帮助你在日志管理方面迈出坚实的第一步!
关注小编,获取更多有关Python和AI技术的实用信息。
相关推荐
- 无敌系统流小说(无敌系统流的小说)
-
《嫡女之花开富贵》作者:伊人睽睽简介祖父是镇国将军,贵不可言;外公是帝师,才名满天下;父母亲琴瑟和鸣,恩爱无双,无妾室插足;穿越为书香门第的嫡小姐,且无任何庶兄妹,慕兰音认为,她这一生,必将佳期如梦...
-
- 键盘上windows键是哪个键(电脑键盘上windows键是哪个)
-
一、台式机键盘。Windows键,简称“Winkey”或“Win键”,是在计算机键盘左下角Ctrl和Alt键之间的按键,台式机全尺寸键盘的主键盘区左下角和右下角各有一个,图案是MicrosoftWindows的视窗徽标。二、笔记...
-
2026-01-13 11:51 off999
-
- 桌面图标设置在哪打开(桌面图标从哪里调出)
-
1、首先来到电脑桌面,此时桌面没有任何图标,如下图所示。2、我们先右键单击任务栏,会出现工具栏,这时我们在下拉的选项里选择“快速启动”按钮。3、单击快速启动按钮后会出现如图所示情况,这时在电脑屏幕的左下方会显示很多快捷按钮,一般情况下单击快...
-
2026-01-13 10:51 off999
- windows如何进入启动项(怎么进入启动选项)
-
方法步骤如下:1.点击应用在Windows设置界面点击应用选项进入。2.选择启动在左侧分类中选择启动选项。3.点击开关点击软件后方的开关即可启动或关闭开机启动项。1、在Window的文件资...
- win11下载安装
-
一、允许安装软件1、首先点击左下角的开始按键,然后点击“settings”进入设置。2、然后点击设置中的“应用”选项。3、在点击左侧任务栏中的“应用和功能”。4、点击下拉栏,然后选择其中的“任何来源”...
- win7支持的最高配置(win7支持的最高配置是多少)
-
答案是支持win7的最高配置应该是i99900k加b365主板。 不过这套配置市面上价格偏高。这种机器比同等酷睿13代处理器的价格还要高至少一千元以上。而且就性能而言要超过i99900...
- 指令引用的内存不能为read(指令引用的0x0000000内存.该内存不能为read)
-
出现“指令引用内存不能为read”的错误可能有多种原因,包括软件冲突、驱动问题、内存质量问题等。以下是一些可能的解决方案:1.检查是否有软件冲突:尝试关闭可能冲突的软件,例如杀毒软件、优化软件等。2...
- hp1010打印机驱动程序(hp deskjet1010打印机驱动)
-
1.把光盘到电脑里然后打开光盘找到“setup.exe”双击运行。2.这里点击“不用了,谢谢,我喜欢CD安装”;下载的驱动也点这个。3.到这个一步有6个软件需要安装,不用点选直接下一步即可。4.同意服...
- 电脑黑屏怎么关机(电脑黑屏怎么关机不会伤硬盘)
-
开机按F8不动到高级选项出现在松手,选“最近一次的正确配置”回车修复,还不行按F8进入安全模式还原一下系统或重装系统(如果开机没反应,放一下电,重新插拔一下硬件,如果总是开不了机就检修一下去)。如果是...
- 应用程序无法启动0xc0000005
-
4、设备主板故障也会导致无信号,建议联系专业的维修人员上门检修。5、设备显卡手指边与手指边插槽接触不良,清理一下显卡的金手指边,重新插回去,重新固定住即可。应用程序错误0xc0000005解决方法如下...
- 移动硬盘分区方法详解(移动硬盘分区步骤)
-
1、进入管理页面将新买的移动硬盘插入计算机的USB接口,右击此电脑后选择管理。2、选择压缩卷在页面里选择“磁盘管理”,右击移动硬盘,选择“压缩卷”。3、输入压缩空间的大小输入压缩空间的大小,点击右下角...
- windows7副本不是正版影响使用吗
-
会经常弹出提示和安全警告,如果我们安装了一个非正版的windows系统,就会经常弹出此windows副本不是正版的提示,那么此windows副本不是正版有什么影响呢,其实除了视觉外,功能也会有影响。w...
-
- 100个有效qq号以及密码2025(2021最新qq号和密码大全)
-
有关QQ登记全国之最的数据目前并没有最新数据更新,最新的该项数据是截止于2019年12月的数据,接下来为大家带来QQ等级全国第一的用户的有关数据,仅供大家娱乐之用:截止2019年12月,全国qq等级第一名的名字叫做“小风波”,QQ等级高达1...
-
2026-01-13 05:51 off999
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
