全网最适合入门的面向对象编程教程:12 类和对象的 Python 实现-Python 使用 logging 模块输出程序运行日志

全网最适合入门的面向对象编程教程:12 类和对象的 Python 实现-Python 使用 logging 模块输出程序运行日志

摘要:

本文主要介绍了日志的定义和作用,以及 Python 内置日志处理的 logging 模块,同时简单说明了日志等级和 logging 模块的简易使用方法。

原文链接:

FreakStudio 的博客

往期推荐:

可能是全网最适合入门的面向对象编程教程:Python实现-嵌入式爱好者必看!

全网最适合入门的面向对象编程教程:00 面向对象设计方法导论

全网最适合入门的面向对象编程教程:01 面向对象编程的基本概念

全网最适合入门的面向对象编程教程:02 类和对象的Python实现-使用Python创建类

全网最适合入门的面向对象编程教程:03 类和对象的Python实现-为自定义类添加属性

全网最适合入门的面向对象编程教程:04 类和对象的 Python 实现-为自定义类添加方法

全网最适合入门的面向对象编程教程:05 类和对象的Python实现-PyCharm代码标签

全网最适合入门的面向对象编程教程:06 类和对象的 Python 实现-自定义类的数据封装

全网最适合入门的面向对象编程教程:07 类和对象的Python实现-类型注解

全网最适合入门的面向对象编程教程:08 类和对象的 Python 实现-@property 装饰器

全网最适合入门的面向对象编程教程:09 类和对象的Python实现-类之间的关系

全网最适合入门的面向对象编程教程:10 类和对象的Python实现-类的继承和里氏替换原则

全网最适合入门的面向对象编程教程:11 类和对象的Python实现-子类调用父类方法

更多精彩内容可看:

CM3调试系统简析

肝了半个月,嵌入式技术栈大汇总出炉

比赛获奖的武林秘籍:05 电子计算机类比赛国奖队伍技术如何分工和学习内容

比赛获奖的武林秘籍:04 电子类比赛嵌入式开发快速必看的上手指南

比赛获奖的武林秘籍:03 好的创意选取-获得国奖的最必要前提

比赛获奖的武林秘籍:02 国奖秘籍-大学生电子计算机类竞赛快速上手的流程,小白必看

比赛获奖的武林秘籍:01 如何看待当代大学生竞赛中“卷”“祖传老项目”“找关系”的现象?

比赛获奖的武林秘籍:00 学科竞赛-工科类大学生绕不开的话题,你了解多少?

电子计算机类比赛的“武林秘籍”-电赛光电设计大赛计算机设计大赛嵌入式芯片与系统设计竞赛,你要的都在这里!

文档和代码获取:

可访问如下链接进行对文档下载:

https://github.com/leezisheng/Doc

image

本文档主要介绍如何使用 Python 进行面向对象编程,需要读者对 Python 语法和单片机开发具有基本了解。相比其他讲解 Python 面向对象编程的博客或书籍而言,本文档更加详细、侧重于嵌入式上位机应用,以上位机和下位机的常见串口数据收发、数据处理、动态图绘制等为应用实例,同时使用 Sourcetrail 代码软件对代码进行可视化阅读便于读者理解。

相关示例代码获取链接如下:https://github.com/leezisheng/Python-OOP-Demo

正文

日志是记录系统中硬件、软件和系统问题的信息,同时还可以监视系统中发生的事件。用户可以通过它来检查错误发生的原因和程序运行历史记录。

在 python3 中,内置了 logging 模块,用于进行日志相关的处理。日志是一种可以追踪某些软件运行时所发生事件的方法。软件开发人员可以向他们的代码中调用日志记录相关的方法来表明发生了某些事情。通过 log 的分析,可以方便用户了解系统或软件、应用的运行情况,日志的作用可以简单总结为以下 3 点:

  • ①程序调试;
  • ②了解软件程序运行情况,是否正常;
  • ③软件程序运行故障分析与问题定位。

logging 模块默认定义了以下几个日志等级用于区别时间严重性:

  • ①DEBUG | 最详细的日志信息,典型应用场景是问题诊断;
  • ②INFO | 信息详细程度仅次于DEBUG,通常只记录关键节点信息,用于确认一切都是按照我们预期的那样进行工作;
  • ③WARNING | 当某些不期望的事情发生时记录的信息(如,磁盘可用空间较低),但是此时应用程序还是正常运行的;
  • ④ERROR | 由于一个更严重的问题导致某些功能不能正常运行时记录的信息;
  • ⑤CRITICAL | 当发生严重错误,导致应用程序不能继续运行时记录的信息。

日志优先级:CRIRICAL>ERROR>WARNING>INFO>DEBUG,当日志级别设置为某个级别时,则低于该级别的日志将不输出。如日志级别设置为 INFO,则 DEBUG 级别的日志将不输出。

这里,我们设置日志优先级为 DEBUG 并使用 logging.info 方法输出调试信息。

此时调试信息从终端输出,也可以保存为 log 文件:

# 在配置下日志输出目标文件和日志格式_
LOG_FORMAT = "%(asctime)s - %(levelname)s - %(message)s"
logging.basicConfig(filename='my.log', level=logging.DEBUG, format=LOG_FORMAT)

在这里插入图片描述

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 08:32:02       3 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 08:32:02       3 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 08:32:02       2 阅读
  4. Python语言-面向对象

    2024-07-10 08:32:02       2 阅读

热门阅读

  1. adb 常用的命令总结

    2024-07-10 08:32:02       12 阅读
  2. gcc: options: -specs

    2024-07-10 08:32:02       7 阅读
  3. Python题解Leetcode Hot 100之栈和堆

    2024-07-10 08:32:02       7 阅读
  4. docker容器如何与本地配置文件关联

    2024-07-10 08:32:02       10 阅读
  5. SQL 字段类型-上

    2024-07-10 08:32:02       14 阅读
  6. C++ 入门04:数组与字符串

    2024-07-10 08:32:02       7 阅读
  7. 简谈设计模式之原型模式

    2024-07-10 08:32:02       10 阅读
  8. GPT带我学-设计模式-13策略模式

    2024-07-10 08:32:02       13 阅读
  9. 写一个字符设备的驱动步骤

    2024-07-10 08:32:02       8 阅读
  10. Transformer和Bert的原理是什么

    2024-07-10 08:32:02       8 阅读
  11. 使用tkinter 制作工作流ui

    2024-07-10 08:32:02       9 阅读