新闻中心

python配置日志记录

2025-11-21
浏览次数:
返回列表
配置Python日志需先调用basicConfig设置级别、格式和输出位置,或创建Logger实例并添加Handler与Formatter以实现多目标输出;对于长期运行服务,应使用RotatingFileHandler或TimedRotatingFileHandler实现按大小或时间轮转日志文件。

python配置日志记录

H3 配置Python日志记录的基本方法

在Python中,logging 模块是内置的日志管理工具,使用它能有效记录程序运行过程中的信息。合理配置日志有助于调试和监控系统行为。

H3 使用 basicConfig 进行简单配置

最基础的配置方式是调用 logging.basicConfig(),可以在程序启动时一次性设置日志格式、输出位置和级别。

示例:

import logging
<p>logging.basicConfig(
level=logging.INFO,                    # 设置最低记录级别
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
filename='app.log',                   # 日志写入文件
filemode='a'                          # 追加模式
)</p><h1>使用日志</h1><p>logging.info("程序启动")
logging.warning("这是一个警告")
logging.error("发生错误")</p>

说明:

  • level:控制哪些级别的日志会被记录(DEBUG
  • format:定义日志输出格式,常用字段包括时间、日志器名、级别、消息内容
  • filename:指定日志文件路径,不设置则默认输出到控制台
  • filemode:'a' 表示追加,'w' 表示每次覆盖

H3 使用 Logger 对象实现更灵活控制

对于复杂项目,推荐创建独立的 Logger 实例,并添加 Handler 和 Formatter。

import logging
<h1>获取一个独立的日志器</h1><p>logger = logging.getLogger('my_app')
logger.setLevel(logging.DEBUG)</p><h1>避免重复输出(防止向上级传递)</h1><p>logger.propagate = False</p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/xiazai/js/4786">
                            <img src="https://img.php.cn/upload/jscode/000/120/096/5db7d8f2e6055653.jpg" alt="数据源可配置的记事日历插件">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/xiazai/js/4786">数据源可配置的记事日历插件</a>
                            <p>数据源可配置的记事日历插件</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="数据源可配置的记事日历插件">
                                <span>52</span>
                            </div>
                        </div>
                        <a href="/xiazai/js/4786" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="数据源可配置的记事日历插件">
                        </a>
                    </div>
                <h1>创建处理器:同时输出到文件和控制台</h1><p>fh = logging.FileHandler('debug.log')
ch = logging.StreamHandler()</p><h1>设置级别</h1><p>fh.setLevel(logging.DEBUG)
ch.setLevel(logging.INFO)</p><h1>定义格式</h1><p>formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(funcName)s - %(message)s')
fh.setFormatter(formatter)
ch.setFormatter(formatter)</p><h1>添加处理器</h1><p>logger.addHandler(fh)
logger.addHandler(ch)</p><h1>使用</h1><p>logger.debug("详细调试信息")
logger.info("普通提示")
logger.error("出错了!")</p>

这种方式的优点:

  • 可为不同模块分配不同的日志器
  • 支持多个输出目标(文件、控制台、网络等)
  • 每个输出可以有不同的格式和级别控制

H3 日志轮转(按大小或时间切割)

长时间运行的服务会产生大量日志,建议使用 RotatingFileHandlerTimedRotatingFileHandler 自动分割日志文件。

from logging.handlers import RotatingFileHandler
import os
<h1>按文件大小轮转</h1><p>handler = RotatingFileHandler(
'app.log',
maxBytes=10<em>1024</em>1024,   # 10MB
backupCount=5            # 保留5个备份
)</p>

from logging.handlers import TimedRotatingFileHandler
import time
<h1>按时间轮转(每天一个文件)</h1><p>handler = TimedRotatingFileHandler(
'app.log',
when='midnight',
interval=1,
backupCount=7,
encoding='utf-8'
)</p><h1>文件名自动加上日期后缀</h1><p>handler.suffix = "%Y-%m-%d"</p>

基本上就这些。根据项目规模选择合适的配置方式,小项目用 basicConfig 就够了,大项目建议使用自定义 Logger + 多处理器的方式,便于维护和排查问题。

以上就是python配置日志记录的详细内容,更多请关注其它相关文章!


# 错了  # 微信加群营销推广  # 简单网站建设方案文档  # 站长之家网站seo排名  # 汽车品牌营销推广方式  # seo排名管理系统  # 网站seo如何优化效果好些  # 宁海网站建设在哪里  # 河源外贸网站建设报价  # 盐城网站建设的公司排名  # 威海网站建设建站  # 解决问题  # 自定义  # 中文网  # 日志记录  # 相关文章  # 这是一个  # 长时间  # 多个  # 如何用  # 多线程  # asic  # gate  # stream  # 工具  # app  # 处理器  # python 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 如何在CSS中使用浮动制作导航栏_float实现水平菜单  J*a递归快速排序中静态变量的状态管理与陷阱  J*aScript中如何高效提取对象指定属性  Python自定义类排序:解决lambda键值访问TypeError的实践指南  MongoDB聚合管道:正确匹配对象数组中_id的方法  Composer如何解决json扩展缺失的错误  动漫岛观看全网网 动漫岛在线正版动漫入口  PrimeNG Sidebar背景色自定义指南:CSS覆盖与主题化实践  服务端验证_j*ascript输入检查  解决移动端滚动问题的overflow属性应用指南  批改网学生版PC登录 批改网官网登录系统入口  抓大鹅无需下载版 抓大鹅秒玩版入口  UE5.7引擎表现爆炸优化无敌!5090跑4K稳定60FPS  豆包手机助手发布技术预览版:直接嵌入手机系统!努比亚样机发售  “音游” × “怪文书” 题材的节奏冒险游戏 《晕晕电波症候群》确定于2026年4月发售!  三星ZFold5多任务卡顿_Samsung ZFold5流畅度提升  Lar*el Excel导入时生成自定义递增ID的策略与实践  支付宝如何管理隐私设置_支付宝隐私保护的配置技巧  Golang如何实现Web接口签名验证_Golang Web接口签名校验开发方法  J*a应用集成GitHub CLI与API认证指南  夸克浏览器网页版最新地址 夸克浏览器官方入口合集  深入理解J*a合成构造器:何时以及为何阻止其生成  MAC如何将整个网页截长图_MAC使用Safari的导出为PDF或第三方工具  html网页设计源代码怎么运行_运行html网页设计源代码步骤【指南】  邮政快递单号查询入口 邮政快递物流信息在线查询入口  win11如何卸载Windows更新补丁 Win11解决更新导致系统不稳定的问题【修复】  处理嵌套交互式控件:前端可访问性指南  TikTok网页版直接登录 TikTok网页端官方平台入口  C++如何打印当前代码行号与文件名_C++预定义宏FILE与LINE的使用  在J*a中如何开发在线活动报名与管理系统_活动报名管理项目实战解析  Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换  J*aScript实现动态背景色下的文本与按钮颜色自适应调整  2306选座时如何选靠窗位置_12306选座靠窗座位查看方法解析  浏览器打开即用 美图秀秀网页版入口  响应式容器内容自动缩放与宽高比维持教程  如何将HTML表格多行数据保存到Google Sheet  微信网页版登录教程_微信网页版登录入口在哪  Win11怎么查看电脑配置_Win11硬件配置检测工具使用  外媒分析《GTA6》定价:卖100美元可以但真没必要!  win11专注助手在哪 Win11免打扰模式设置与自动化规则【指南】  小红书网页版入口链接分享 小红书官网直接进  漫蛙网页登录入口 漫蛙漫画官方授权网址  PySpark中从现有列右侧提取可变长度字符创建新列的教程  在J*a里如何理解依赖关系的方向_依赖方向在模块结构中的作用  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  b站怎么看视频的弹幕数量_b站弹幕数量查看方法  利用Bokeh CustomJS动态控制DataTable列可见性  飞书妙记怎样用语音转文字速记_飞书妙记用语音转文字速记【速记方法】  C++如何操作注册表_Windows平台下C++读写注册表的API函数详解  Node.js CSV 数据处理:基于字段空值条件过滤整条记录的策略 

搜索