- 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 - 元组(Tuple )
- Python - 访问元组项
- Python - 更新元组
- Python - 解压缩元组项
- Python - 循环元组
- Python - 联接元组
- Python - 元组方法
- Python - 元组练习
- Python 集
- Python - 集(sets)
- Python - 访问 Set Items
- Python - 添加 Set Items
- Python - 删除 Set Items
- Python - 循环 Set Items
- Python - 联接 Sets
- Python - 复制 Set
- Python - Set 运算符
- Python - Set 方法
- Python - Set 的练习
- 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 文件/目录方法
- 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 - 异常处理
- 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 - 日期和时间
- Python - math 模块
- Python - 迭代器
- Python - 生成器
- Python - 闭包(closures)
- Python - 装饰器( Decorators)
- Python - 递归
- Python - 正则表达式
- Python - PIP
- Python - 数据库访问
- Python - 弱引用
- Python - 序列化
- Python - 模板
- Python - 输出格式
- Python - 性能测量
- Python - 数据压缩
- Python - CGI 编程
- Python - XML 处理
- Python - GUI 编程
- Python - 命令行参数
- Python - 文档字符串
- Python - JSON
- Python - 发送电子邮件
- Python - 更多扩展
- Python - 工具/实用程序
- Python - 图形用户界面
- Python 高级概念
- Python - 抽象基类
- Python - 自定义异常
- Python - 高阶函数
- Python - 对象内部
- Python - 内存管理
- Python - 元类
- Python - 使用 Metaclasses 进行元编程
- Python - 模拟和存根
- Python - 猴子修补
- Python - 信号处理
- Python - 类型提示
- Python - 自动化教程
- Python - 人性化软件包
- Python - 上下文管理器
- Python - 协程
- Python - 描述符
- Python - 诊断和修复内存泄漏
- Python - 不可变数据结构
Python - 日志记录
Python 中的日志记录
日志记录是在程序执行期间记录消息的过程,以提供可用于监视、调试和审计的运行时信息。
在 Python 中,日志记录是通过内置的 logging 模块实现的,该模块为生成日志消息提供了一个灵活的框架。
日志记录的好处
以下是在 Python 中使用日志记录的好处 -
- 调试 - 通过在程序执行期间捕获相关信息来帮助识别和诊断问题。
- 监控 - 提供对应用程序行为和性能的见解。
- 审计 - 出于安全目的,保留重要事件和操作的记录。
- 故障排除 - 有助于跟踪程序流和变量值,以了解意外行为。
Python 日志记录的组件
Python 日志记录由几个关键组件组成,这些组件协同工作以有效地管理和输出日志消息 -
- 记录器 -它是用于发出日志消息的主入口点。每个 Logger 实例都有名称,可以独立配置。
- 处理程序 -它确定日志消息的发送位置。处理程序将日志消息发送到不同的目标,例如控制台、文件、套接字等。
- 格式化程序 -它指定日志消息的布局。格式化程序通过指定要包含的信息(例如,时间戳、日志级别、消息)来定义日志记录的结构。
- 记录器级别 -它定义日志消息的严重性级别。低于此级别的消息将被忽略。常见级别包括 DEBUG、INFO、WARNING、ERROR 和 CRITICAL。
- 过滤器 −可选组件可以更精细地控制处理程序处理和发出哪些日志记录。
日志记录级别
Python 中的日志记录级别定义了日志消息的严重性,允许开发人员根据消息的重要性对消息进行分类和筛选。每个日志记录级别都有特定的用途,有助于了解记录信息的重要性 -
- 调试 -详细信息,通常仅用于调试目的。这些消息用于跟踪程序的流,通常在生产环境中看不到。
- 信息 -确认一切按预期进行。这些消息提供有关应用程序进度的一般信息。
- 警告 -指示不会阻止程序运行但可能需要注意的潜在问题。这些消息可用于提醒开发人员注意意外情况。
- 错误 -表示阻止特定功能或操作成功完成的更严重问题。这些消息突出显示了需要立即注意的错误,但不一定会终止应用程序。
- 严重 -最严重级别,表示可能导致程序终止的严重错误。这些消息是为需要立即干预的严重故障保留的。
用法
以下是 Python 应用程序中每个日志记录级别的使用方案 -
- 选择正确的级别 -选择适当的日志记录级别可确保日志消息提供相关信息,而不会使日志混乱。
- 设置级别 -Logger、处理程序和特定日志消息可以配置不同的级别,以控制记录哪些消息以及输出消息的位置。
- 层次结构 -日志记录级别是分层的,这意味着在 Logger 上设置级别也会影响处理程序和与之关联的日志消息。
基本日志记录示例
以下是 Python 中的一个基本日志记录示例,用于演示其用法和功能 -
import logging
# Configure logging
logging.basicConfig(level=logging.DEBUG, format='%(asctime)s - %(levelname)s - %(message)s')
# Example usage
def calculate_sum(a, b):
logging.debug(f"Calculating sum of {a} and {b}")
result = a + b
logging.info(f"Sum calculated successfully: {result}")
return result
# Main program
if __name__ == "__main__":
logging.info("Starting the program")
result = calculate_sum(10, 20)
logging.info("Program completed")
输出
以下是上述代码的输出 -
2024-06-19 09:00:06,774 - INFO - Starting the program
2024-06-19 09:00:06,774 - DEBUG - Calculating sum of 10 and 20
2024-06-19 09:00:06,774 - INFO - Sum calculated successfully: 30
2024-06-19 09:00:06,775 - INFO - Program completed
2024-06-19 09:00:06,774 - DEBUG - Calculating sum of 10 and 20
2024-06-19 09:00:06,774 - INFO - Sum calculated successfully: 30
2024-06-19 09:00:06,775 - INFO - Program completed
配置日志记录
在 Python 中配置日志记录是指设置各种组件(如 Logger、处理程序和格式化程序)来控制日志消息的存储和显示方式和位置。此配置允许开发人员根据其应用程序的要求和部署环境自定义日志记录行为。
例在以下示例中,getLogger() 函数检索或创建命名记录器。Logger 根据其名称按层次结构进行组织。然后,创建诸如 “StreamHandler” (控制台处理程序) 之类的处理程序来定义日志消息的去向。它们可以配置特定的日志级别和格式化程序。
格式化程序指定日志记录的布局,确定日志消息在打印或存储时的显示方式 -
import logging
# Create logger
logger = logging.getLogger('my_app')
logger.setLevel(logging.DEBUG) # Set global log level
# Create console handler and set level to debug
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)
# Create formatter
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
console_handler.setFormatter(formatter)
# Add console handler to logger
logger.addHandler(console_handler)
# Example usage
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')
生成的结果如下所示 -
2024-06-19 09:05:20,852 - my_app - DEBUG - This is a debug message
2024-06-19 09:05:20,852 - my_app - INFO - This is an info message
2024-06-19 09:05:20,852 - my_app - WARNING - This is a warning message
2024-06-19 09:05:20,852 - my_app - ERROR - This is an error message
2024-06-19 09:05:20,852 - my_app - CRITICAL - This is a critical message
2024-06-19 09:05:20,852 - my_app - INFO - This is an info message
2024-06-19 09:05:20,852 - my_app - WARNING - This is a warning message
2024-06-19 09:05:20,852 - my_app - ERROR - This is an error message
2024-06-19 09:05:20,852 - my_app - CRITICAL - This is a critical message
日志记录处理程序
Python 中的日志记录处理程序确定处理和输出日志消息的位置和方式。它们在将日志消息定向到特定目标(如控制台、文件、电子邮件、数据库甚至远程服务器)方面发挥着重要作用。
每个处理程序都可以独立配置,以控制它处理的消息的格式、日志级别和其他属性。
日志记录处理程序的类型
以下是 Python 中各种类型的日志记录处理程序 -
- StreamHandler - 流处理程序 -将日志消息发送到 sys.stdout 或 sys.stderr 等流。用于在控制台或命令行界面中显示日志消息。
- FileHandler 文件处理程序 -将日志消息写入文件系统上的指定文件。对于日志数据的持久日志记录和存档非常有用。
- RotatingFileHandler -与 FileHandler 类似,但会根据大小或时间间隔自动轮换日志文件。帮助管理日志文件大小并防止它们变得太大。
- SMTPHandler -通过 SMTP 将日志消息作为电子邮件发送给指定的收件人。用于提醒管理员或开发人员有关关键问题的信息。
- SysLogHandler -将日志消息发送到类 Unix 系统(例如 syslog)上的系统日志。允许与系统范围的日志记录工具集成。
- MemoryHandler -缓冲区在内存中记录消息,并在达到特定缓冲区大小或超时后将其发送到目标处理程序。对于批处理和管理日志消息的突发非常有用。
- HTTPHandler -通过 HTTP 或 HTTPS 将日志消息发送到 Web 服务器。允许将消息记录到远程服务器或记录服务。