主页
  • 主页
  • 分类
  • 热文
  • 教程
  • 面试
  • 标签
Python

Python 基础

Python 主页
Python 概述
Python 历史
Python 功能
Python 与 C++
Python Hello World
Python 应用领域
Python 解释器及其模式
Python 环境设置
Python 虚拟环境
Python 语法
Python 变量
Python 数据类型
Python 类型转换
Python Unicode 系统
Python 文字
Python 运算符
Python 算术运算符
Python 比较运算符
Python 赋值运算符
Python 逻辑运算符
Python 位运算符
Python 成员运算符
Python 身份运算符
Python 运算符优先级
Python 注释
Python 用户输入
Python 数字
Python 布尔值

Python 控制语句

Python 控制流
Python 决策
Python if 语句
Python if-else 语句
Python 嵌套 if 语句
Python match-case 语句
Python 循环
Python For 循环
Python for-else 循环
Python while 循环
Python break 语句
Python Continue 语句
Python pass 语句
Python 嵌套循环

Python 函数和模块

Python 函数
Python 默认参数
Python 关键字参数
Python 关键字专用参数
Python 位置参数
Python 仅限位置参数
Python 任意或可变长度参数
Python 变量作用域
Python 函数注释
Python 模块
Python 内置函数

Python 字符串

Python 字符串
Python 字符串切片
Python 字符串修改
Python 字符串连接
Python 字符串格式化
Python 转义字符
Python 字符串方法
Python 字符串练习

Python 列表

Python 列表
Python 访问列表项
Python 更改列表项
Python 添加列表项
Python 删除列表项
Python 循环列表
Python 列表推导式
Python 排序列表
Python 复制列表
Python 合并列表
Python 列表方法
Python 列表练习

Python 元组

Python 元组
Python 访问元组项
Python 更新元组
Python 解包元组项
Python 循环元组
Python 合并元组
Python 元组方法
Python 元组练习

Python 集合

Python 集合
Python 访问集合项
Python 添加集合项
Python 删除集合项
Python 循环集合
Python 合并集合
Python 复制集合
Python 集合运算符
Python 集合方法
Python 集合练习

Python 字典

Python 字典
Python 访问字典项
Python 更改字典项
Python 添加字典项
Python 移除字典项
Python 字典视图对象
Python 循环字典
Python 复制字典
Python 嵌套字典
Python 字典方法
Python 字典练习

Python 数组

Python 数组
Python 访问数组项
Python 添加数组项
Python 移除数组项
Python 循环数组
Python 复制数组
Python 反转数组
Python 排序数组
Python 合并数组
Python 数组方法
Python 数组练习

Python 文件处理

Python 文件处理
Python 文件写入
Python 文件读取
Python 重命名和删除文件
Python 目录
Python 文件方法
Python 文件/目录方法
Python OS.Path 方法

Python 面向对象编程

Python OOP 概念
Python 类和对象
Python 类属性
Python 类方法
Python 静态方法
Python 构造函数
Python 访问修饰符
Python 继承
Python 多态
Python 方法重写
Python 方法重载
Python 动态绑定
Python 动态类型
Python 抽象
Python 封装
Python 接口
Python 包
Python 内部类
Python 匿名类和对象
Python 单例类
Python 包装器类
Python 枚举
Python 反射

Python 错误和异常

Python 语法错误
Python 异常处理
Python Try-Except
Python Try-Finally
Python 抛出异常
Python 异常链
Python 嵌套 try
Python 用户定义异常
Python 日志记录
Python 断言
Python 内置异常

Python 多线程

Python 多线程
Python 线程生命周期
Python 创建线程
Python 启动线程
Python 合并线程
Python 命名线程
Python 线程调度
Python 线程池
Python 主线程
Python 线程优先级
Python 守护线程
Python 线程同步

Python 同步

Python 线程间通信
Python 死锁
Python 中断线程

Python 网络

Python 网络编程
Python 套接字编程
Python URL 处理
Python 泛型

Python 杂项

Python Date and Time
Python math模块
Python 迭代器
Python 生成器
Python 闭包
Python 装饰器
Python 递归
Python 正则表达式
Python Pip
Python 数据库访问
Python 弱引用
Python 序列化
Python 模板技术
Python 输出格式化
Python 性能测量
Python 数据压缩
Python 通用网关接口
Python XML 处理
Python 用户界面(GUI)
Python 命令行参数
Python Docstrings
Python JSON
Python 发送电子邮件
Python 进一步扩展
Python 工具/实用程序
Python GUI

Python 高级概念

Python 抽象基类
Python 自定义异常
Python 高阶函数
Python 对象的内部机制
Python 内存管理
Python 元类
Python 元编程
Python 模拟与桩
Python 猴子补丁
Python 信号处理
Python 类型提示
Python 进行自动化
Python Humanize包
Python 上下文管理器
Python 协程
Python 描述符
Python 内存泄漏
Python 不可变数据结构

基础

Python 主页
Python 概述
Python 历史
Python 功能
Python 与 C++
Python Hello World
Python 应用领域
Python 解释器及其模式
Python 环境设置
Python 虚拟环境
Python 语法
Python 变量
Python 数据类型
Python 类型转换
Python Unicode 系统
Python 文字
Python 运算符
Python 算术运算符
Python 比较运算符
Python 赋值运算符
Python 逻辑运算符
Python 位运算符
Python 成员运算符
Python 身份运算符
Python 运算符优先级
Python 注释
Python 用户输入
Python 数字
Python 布尔值

控制语句

Python 控制流
Python 决策
Python if 语句
Python if-else 语句
Python 嵌套 if 语句
Python match-case 语句
Python 循环
Python For 循环
Python for-else 循环
Python while 循环
Python break 语句
Python Continue 语句
Python pass 语句
Python 嵌套循环

函数和模块

Python 函数
Python 默认参数
Python 关键字参数
Python 关键字专用参数
Python 位置参数
Python 仅限位置参数
Python 任意或可变长度参数
Python 变量作用域
Python 函数注释
Python 模块
Python 内置函数

字符串

Python 字符串
Python 字符串切片
Python 字符串修改
Python 字符串连接
Python 字符串格式化
Python 转义字符
Python 字符串方法
Python 字符串练习

列表

Python 列表
Python 访问列表项
Python 更改列表项
Python 添加列表项
Python 删除列表项
Python 循环列表
Python 列表推导式
Python 排序列表
Python 复制列表
Python 合并列表
Python 列表方法
Python 列表练习

元组

Python 元组
Python 访问元组项
Python 更新元组
Python 解包元组项
Python 循环元组
Python 合并元组
Python 元组方法
Python 元组练习

集合

Python 集合
Python 访问集合项
Python 添加集合项
Python 删除集合项
Python 循环集合
Python 合并集合
Python 复制集合
Python 集合运算符
Python 集合方法
Python 集合练习

字典

Python 字典
Python 访问字典项
Python 更改字典项
Python 添加字典项
Python 移除字典项
Python 字典视图对象
Python 循环字典
Python 复制字典
Python 嵌套字典
Python 字典方法
Python 字典练习

数组

Python 数组
Python 访问数组项
Python 添加数组项
Python 移除数组项
Python 循环数组
Python 复制数组
Python 反转数组
Python 排序数组
Python 合并数组
Python 数组方法
Python 数组练习

文件处理

Python 文件处理
Python 文件写入
Python 文件读取
Python 重命名和删除文件
Python 目录
Python 文件方法
Python 文件/目录方法
Python OS.Path 方法

面向对象编程

Python OOP 概念
Python 类和对象
Python 类属性
Python 类方法
Python 静态方法
Python 构造函数
Python 访问修饰符
Python 继承
Python 多态
Python 方法重写
Python 方法重载
Python 动态绑定
Python 动态类型
Python 抽象
Python 封装
Python 接口
Python 包
Python 内部类
Python 匿名类和对象
Python 单例类
Python 包装器类
Python 枚举
Python 反射

错误和异常

Python 语法错误
Python 异常处理
Python Try-Except
Python Try-Finally
Python 抛出异常
Python 异常链
Python 嵌套 try
Python 用户定义异常
Python 日志记录
Python 断言
Python 内置异常

多线程

Python 多线程
Python 线程生命周期
Python 创建线程
Python 启动线程
Python 合并线程
Python 命名线程
Python 线程调度
Python 线程池
Python 主线程
Python 线程优先级
Python 守护线程
Python 线程同步

同步

Python 线程间通信
Python 死锁
Python 中断线程

网络

Python 网络编程
Python 套接字编程
Python URL 处理
Python 泛型

杂项

Python Date and Time
Python math模块
Python 迭代器
Python 生成器
Python 闭包
Python 装饰器
Python 递归
Python 正则表达式
Python Pip
Python 数据库访问
Python 弱引用
Python 序列化
Python 模板技术
Python 输出格式化
Python 性能测量
Python 数据压缩
Python 通用网关接口
Python XML 处理
Python 用户界面(GUI)
Python 命令行参数
Python Docstrings
Python JSON
Python 发送电子邮件
Python 进一步扩展
Python 工具/实用程序
Python GUI

高级概念

Python 抽象基类
Python 自定义异常
Python 高阶函数
Python 对象的内部机制
Python 内存管理
Python 元类
Python 元编程
Python 模拟与桩
Python 猴子补丁
Python 信号处理
Python 类型提示
Python 进行自动化
Python Humanize包
Python 上下文管理器
Python 协程
Python 描述符
Python 内存泄漏
Python 不可变数据结构

Python 日志记录


上一章 下一章

日志记录是在程序执行期间记录消息的过程,提供可用于监控、调试和审计的运行时信息。

在 Python 中,通过内置的 logging 模块来实现日志记录,它提供了一个灵活的框架来生成日志消息。

日志记录的好处

以下是使用 Python 中的日志记录的好处:

  • 调试 — 通过在程序执行期间捕获相关信息来帮助识别和诊断问题。
  • 监控 — 提供应用行为和性能的洞察。
  • 审计 — 为安全目的保留重要事件和操作的记录。
  • 故障排除 — 有助于追踪程序流程和变量值,以理解意外的行为。

Python 日志记录的组件

Python 日志记录由几个关键组件组成,它们协同工作以有效地管理和输出日志消息:

  • Logger — 它是你用来发出日志消息的主要入口点。每个 Logger 实例都是命名的,并且可以独立配置。
  • Handler — 它决定了日志消息发送的位置。Handlers 将日志消息发送到不同的目的地,如控制台、文件、套接字等。
  • Formatter — 它指定了日志消息的布局。Formatters 通过指定包含哪些信息(如时间戳、日志级别、消息)来定义日志记录的结构。
  • Logger 级别 — 它定义了日志消息的严重程度。低于此级别的消息会被忽略。常见的级别包括 DEBUG、INFO、WARNING、ERROR 和 CRITICAL。
  • Filter — 它是可选组件,提供了对哪些日志记录被处理和发出的更细粒度的控制。

日志级别

Python 中的日志级别定义了日志消息的严重程度,允许开发人员根据消息的重要性对其进行分类和过滤。每个日志级别都有特定的目的,并有助于理解日志信息的重要性:

  • DEBUG — 详细信息,通常仅用于调试目的。这些消息用于跟踪程序流程,在生产环境中通常不可见。
  • INFO — 确认事情按预期进行。这些消息提供了关于应用程序进度的一般信息。
  • WARNING — 表明可能的问题,不会阻止程序运行但可能需要关注。这些消息可用于提醒开发人员注意意外的情况。
  • ERROR — 表明更严重的问题,阻止某个特定功能或操作成功完成。这些消息突显了需要立即注意的错误,但不一定终止应用程序。
  • CRITICAL — 最严重的级别,表明可能导致程序终止的关键错误。这些消息是为那些需要立即干预的关键失败保留的。

使用场景

以下是 Python 应用程序中每个日志级别的使用场景:

  • 选择正确的级别 — 选择适当的日志级别可以确保日志消息提供相关信息而不至于杂乱无章。
  • 设置级别 — Loggers、handlers 和特定的日志消息可以被配置为不同的级别,以控制哪些消息被记录以及它们被输出到哪里。
  • 层次结构 — 日志级别是分层的,这意味着在一个 logger 上设置级别也会影响与其关联的 handlers 和日志消息。

基本的日志记录示例

以下是一个基本的日志记录示例,用于演示其用法和功能:

import logging

# 配置日志记录
logging.basicConfig(level=logging.DEBUG, format='%(asctime)s - %(levelname)s - %(message)s')

# 示例用法
def calculate_sum(a, b):
   logging.debug(f"计算 {a} 和 {b} 的和")
   result = a + b
   logging.info(f"和计算成功: {result}")
   return result

# 主程序
if __name__ == "__main__":
   logging.info("开始程序")
   result = calculate_sum(10, 20)
   logging.info("程序完成")

输出

2024-06-19 09:00:06,774 - INFO - 开始程序
2024-06-19 09:00:06,774 - DEBUG - 计算 10 和 20 的和
2024-06-19 09:00:06,774 - INFO - 和计算成功: 30
2024-06-19 09:00:06,775 - INFO - 程序完成

配置日志记录

在 Python 中配置日志记录指的是设置各种组件,如 loggers、handlers 和 formatters,以控制日志消息如何存储和显示。这种配置允许开发人员根据他们的应用程序需求和部署环境自定义日志行为。

示例

在以下示例中,getLogger() 函数检索或创建一个命名的 logger。Loggers 根据它们的名字层级组织。然后,创建像 "StreamHandler"(控制台 handler)这样的 handlers 来定义日志消息的去向。它们可以被配置为特定的日志级别和 formatters。

Formatters 指定了日志记录的布局,确定了当打印或存储日志消息时它们的外观:

import logging

# 创建 logger
logger = logging.getLogger('my_app')
logger.setLevel(logging.DEBUG)  # 设置全局日志级别

# 创建控制台 handler 并设置级别为 debug
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)

# 创建 formatter
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
console_handler.setFormatter(formatter)

# 将控制台 handler 添加到 logger
logger.addHandler(console_handler)

# 示例用法
logger.debug('这是一个调试消息')
logger.info('这是一个信息消息')
logger.warning('这是一个警告消息')
logger.error('这是一个错误消息')
logger.critical('这是一个严重消息')

产生的结果如下:

2024-06-19 09:05:20,852 - my_app - DEBUG - 这是一个调试消息
2024-06-19 09:05:20,852 - my_app - INFO - 这是一个信息消息
2024-06-19 09:05:20,852 - my_app - WARNING - 这是一个警告消息
2024-06-19 09:05:20,852 - my_app - ERROR - 这是一个错误消息
2024-06-19 09:05:20,852 - my_app - CRITICAL - 这是一个严重消息

日志记录处理器

Python 中的日志记录处理器决定了日志消息被处理和输出的位置和方式。它们在将日志消息定向到特定目的地方面起着重要作用,如控制台、文件、邮件、数据库,甚至是远程服务器。

每个处理器都可以独立配置,以控制其处理的消息的格式、日志级别和其他属性。

日志处理器类型

以下是 Python 中的各种类型的日志处理器:

  • StreamHandler — 将日志消息发送到流,如 sys.stdout 或 sys.stderr。适用于在控制台或命令行界面显示日志消息。
  • FileHandler — 将日志消息写入文件系统上的指定文件。适用于持久化日志记录和日志数据存档。
  • RotatingFileHandler — 类似于 FileHandler,但基于大小或时间间隔自动旋转日志文件。有助于管理日志文件大小,防止其变得过大。
  • SMTPHandler — 通过 SMTP 发送日志消息作为电子邮件给指定的接收者。适用于在出现关键问题时提醒管理员或开发人员。
  • SysLogHandler — 在类 Unix 系统(如 syslog)上发送日志消息到系统日志。允许集成到系统级的日志设施。
  • MemoryHandler — 在达到一定缓冲区大小或超时后将日志消息缓冲在内存中并发送到目标处理器。适用于批处理和管理日志消息的爆发。
  • HTTPHandler — 通过 HTTP 或 HTTPS 将日志消息发送到 Web 服务器。允许将日志消息发送到远程服务器或日志服务。
上一章 下一章
阅读号二维码

关注阅读号

联系二维码

联系我们

© 2024 Yoagoa. All rights reserved.

粤ICP备18007391号

站点地图