Python里logging模块配置 Python标准日志模块logging最佳实践

pythonlogging模块的正确使用方法包括:1.基础配置,设置日志级别和格式;2.使用logger对象区分模块来源并单独控制日志级别;3.添加filehandler将日志写入文件并保留控制台输出;4.上线前关闭debug日志、用模块名命名logger、避免在库代码中配置logging、使用dictconfig做复杂配置。logging.basicconfig设置级别和格式,logger = logging.getlogger(__name__)创建模块logger,同时添加streamhandler和filehandler实现多输出,并通过setlevel控制不同模块或全局的日志级别,确保日志结构清晰且便于维护。

在Python项目中,logging模块是记录日志的首选工具。它灵活、功能强大,但很多人用不好,导致日志信息混乱、缺失或难以维护。配置好logging,不仅能帮助排查问题,还能提升系统的可观测性。

基本配置:别再用print了

刚开始用logging时,很多人直接logging.info("something"),这样虽然比print强点,但远远不够。建议一开始就做基础配置:

import logginglogging.basicConfig(level=logging.INFO)

这一步设定了最低日志级别为INFO,意味着DEBUG级别的日志不会显示。如果你希望看到更详细的日志,可以改成DEBUG;如果只关心错误,可以设成WARNING。

另外,建议设置格式和时间戳,比如:

立即学习“Python免费学习笔记(深入)”;

logging.basicConfig(    level=logging.INFO,    format='%(asctime)s - %(levelname)s - %(message)s')

这样每条日志都有时间、级别和内容,看起来清晰多了。

使用logger而不是直接调用logging

很多人习惯直接使用logging.info()这样的写法,但在实际项目中,尤其是多个模块协同工作时,应该使用logger对象。例如:

logger = logging.getLogger(__name__)logger.info("This is an info log")

好处有几个:

每个模块有自己的logger,便于区分来源可以单独控制不同模块的日志级别更容易添加handler、formatter等高级配置

举个例子,你有两个模块main.pyutils.py,分别获取各自的logger:

# main.pylogger = logging.getLogger(__name__)  # __name__ 是 'main'# utils.pylogger = logging.getLogger(__name__)  # __name__ 是 'utils'

之后你可以单独设置某个模块的日志级别,比如让utils输出DEBUG级别的日志,而main只输出INFO以上:

logging.getLogger('utils').setLevel(logging.DEBUG)

把日志写入文件,同时保留控制台输出

开发时看控制台没问题,但上线后通常需要把日志保存下来。这时候就需要添加FileHandler。

一个典型的配置方式如下:

import logginglogger = logging.getLogger(__name__)logger.setLevel(logging.INFO)# 控制台输出console_handler = logging.StreamHandler()console_handler.setLevel(logging.INFO)# 文件输出file_handler = logging.FileHandler('app.log')file_handler.setLevel(logging.INFO)# 设置格式formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')console_handler.setFormatter(formatter)file_handler.setFormatter(formatter)# 添加到loggerlogger.addHandler(console_handler)logger.addHandler(file_handler)

这样你的日志就会同时出现在终端和文件里,结构清晰、方便查看。

注意:如果你用了多个handler,记得不要重复添加,否则可能出现日志重复打印的问题。可以通过logger.handlers检查当前绑定的handler。

此外,还可以考虑使用RotatingFileHandler或TimedRotatingFileHandler来实现日志滚动,避免单个日志文件过大或过久。

最后几点小建议

别忘了关闭DEBUG日志:上线前确保日志级别不是DEBUG,避免产生大量无用信息。命名logger时尽量用模块名:像logging.getLogger(__name__)这种做法能保证层级清晰。避免在库代码中配置logging:作为第三方库开发者,不应该主动配置root logger,而是让使用者去统一管理。可以用dictConfig做更复杂的配置:对于大型项目,用字典形式配置logging会更清晰、易维护。

基本上就这些。logging不算难,但细节不少,稍不注意就踩坑。掌握这几个关键点,基本就能应付大多数场景了。

以上就是Python里logging模块配置 Python标准日志模块logging最佳实践的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1362634.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 02:01:29
下一篇 2025年12月14日 02:01:49

相关推荐

  • Python语音识别 Python语音转文本技术实现

    python实现语音识别需选对工具并理清流程,常用库包括speechrecognition、pyaudio和whisper。使用speechrecognition的步骤为:安装库、录音并调用api识别;而whisper模型则支持离线高精度识别,需安装依赖并加载模型处理音频文件。实际应用中应注意音频格…

    2025年12月14日
    000
  • Python加密解密技术 Python常见加密算法实现解析

    python 实现加密的方法包括:1. 哈希加密使用 md5 和 sha 系列生成数据指纹,推荐 sha-256 或以上版本;2. 对称加密使用 aes,适合加密大量数据,需注意模式选择和密钥保密;3. 非对称加密使用 rsa,用于身份认证和数字签名,结合对称加密提升效率;4. 实际应用建议加 sa…

    2025年12月14日
    000
  • Python聊天机器人 Python NLP对话系统开发

    用 python 做聊天机器人可分为三个主要步骤:1. 从简单对话系统开始,可使用 chatterbot 库快速搭建基于语料训练的机器人,适合演示或测试但智能化程度有限;2. 利用 nlp 技术提升理解能力,包括意图识别、实体提取和语义相似度匹配,常用工具如 rasa、spacy 和 sentenc…

    2025年12月14日
    000
  • Python数据分析实战指南 Python数据分析常用方法介绍

    数据分析需先清洗数据,再通过探索性分析指导建模,最后用合适方法与可视化呈现结果。首先数据清洗包括处理缺失值、异常值、重复数据及格式转换,如用pandas.isna()检测缺失值,fillna()填充,箱线图识别异常值;其次探索性分析(eda)通过直方图、散点图、describe()和相关系数矩阵了解…

    2025年12月14日
    000
  • Python里decimal模块 高精度小数decimal的财务计算优势

    不能用 float 做财务计算的原因有:1.浮点数基于二进制表示,无法准确表达某些十进制小数;2.多次运算后误差会累积,导致结果不可控;3.不符合会计四舍五入规范,影响审计和报表。decimal 模块通过以下方式解决这些问题:1.使用字符串初始化避免精度问题;2.支持设置全局或局部精度(默认 28 …

    好文分享 2025年12月14日
    000
  • Python里multiprocessing 多进程编程multiprocessing的进程池

    进程池是python中用于并行执行任务的工具,核心是multiprocessing.pool类。它能自动管理进程数量、任务分配和结果回收,适合cpu密集型任务。使用流程:1.导入pool模块;2.定义要执行的函数;3.创建进程池并用map或apply_async提交任务。注意事项包括:1.进程数建议…

    好文分享 2025年12月14日
    000
  • Python里urllib.request 网络请求模块urllib的核心功能详解

    python中urllib.request的核心用途是发送网络请求并获取响应,其作为标准库适用于轻量级或受限环境。1. 它可通过urlopen()发起get请求,并支持设置超时;2. 使用request对象可自定义请求头、发送post数据;3. 可结合http.cookiejar处理cookie以保…

    好文分享 2025年12月14日
    000
  • Python中queue.Queue用法 队列Queue在多线程编程中的应用解析

    在多线程中使用queue.queue是因为其线程安全特性可避免数据竞争。1.queue.queue内置锁机制,确保多线程访问安全;2.适用于生产者-消费者模型,自动处理任务调度;3.常用方法put()和get()支持阻塞与非阻塞操作;4.可选择lifoqueue(后进先出)或priorityqueu…

    好文分享 2025年12月14日
    000
  • Python高性能计算 Python代码加速优化技巧大全

    python能胜任高性能计算吗?答案是肯定的,只要方法得当。关键在于优化方式:1. 尽量使用内置函数和标准库,例如列表推导式、map()、itertools等,它们内部用c实现,效率更高;2. 用numpy替代原生列表进行数值计算,其底层为c编写,速度显著提升,尤其适合大规模数据操作;3. 使用cy…

    2025年12月14日
    000
  • Python反爬对抗 Python爬虫伪装技术大全

    做爬虫时绕过反爬机制的关键在于伪装成正常用户。1. 设置随机user-agent模拟浏览器访问,使用fake_useragent库随机生成不同ua。2. 使用代理ip避免ip封禁,维护代理池并定期检测可用性。3. 控制请求频率并加入随机延迟,模拟人类行为降低风险。4. 使用selenium或play…

    2025年12月14日
    000
  • python中怎么安装pip python包管理工具安装指南

    pip在python 3.4及以上版本中默认安装。如果未安装,可通过下载get-pip.py并运行python get-pip.py来安装。使用pip3避免版本混淆,建议使用镜像源并定期更新pip。 在Python中安装pip——Python包管理工具的详细指南你问我怎么在Python中安装pip?…

    2025年12月14日
    000
  • Python代码打包发布 Python项目打包成可执行文件步骤

    打包python程序成可执行文件并不复杂,关键在于选对工具和注意细节。首先,pyinstaller是最常用、跨平台且操作简单的工具,基本命令为pyinstaller -f main.py;其次,更复杂的项目可选用cx_freeze或nuitka;接着,打包前需确保代码无误、依赖明确、资源完整,并建议…

    2025年12月14日
    000
  • Python里struct模块 字节流打包解包struct的二进制处理

    struct模块是 格式字符串 ‘i’ 表示使用默认的字节序(一般是小端)。如果你要指定大端或小端,可以加前缀: unpack:把 bytes 解包回原始值 value = struct.unpack(‘i’, data)print(value) # 输出 (12345,) 注意返回的是一个元组,即…

    好文分享 2025年12月14日
    000
  • Python类型注解指南 Python类型提示使用方法详解

    类型注解是python中一种为变量、函数参数及返回值添加类型信息的技术,它提升代码可读性和维护性。例如,函数greet(name: str) -> str指定参数和返回值应为字符串。变量如age: int = 25也可加注解。对于函数,即使有默认参数也应加类型,无返回值用none,不确定类型可…

    2025年12月14日
    000
  • Python交互设计 Python命令行界面优化技巧

    提升python命令行程序交互体验的关键在于优化提示信息、输入验证和输出美化。首先,给出明确提示,如“请输入1到10之间的整数”或带默认值的提示,帮助用户了解输入要求;其次,加入输入验证逻辑,使用循环和异常处理防止因错误输入导致程序崩溃;最后,通过分隔线、颜色高亮和第三方库如tabulate、col…

    2025年12月14日
    000
  • Python科学计算库教程 Python科学计算必备模块有哪些

    python科学计算流行因其强大库支持,关键模块包括numpy、pandas、matplotlib+seaborn、scipy。1.numpy提供高效多维数组和向量化运算,是科学计算基础;2.pandas基于numpy,核心结构dataframe适合处理表格型数据,涵盖读取、清洗、聚合等操作;3.m…

    2025年12月14日
    000
  • Python中如何计算三角形的面积?

    如何计算三角形的面积?在python中可以通过公式面积 = 0.5 底 高来计算。具体实现包括:1. 定义函数calculate_triangle_area(base, height),使用浮点数计算面积;2. 使用decimal模块进行更精确的计算;3. 加入错误处理,确保输入为正数;4. 利用n…

    2025年12月14日
    000
  • Python中如何处理异步Web请求?

    在python中,处理异步web请求主要依赖于asyncio和aiohttp库。使用这些库可以提高代码效率和响应速度。具体方法包括:1)使用aiohttp发起异步http请求;2)并行处理多个请求以提高性能;3)注意代码结构清晰、使用异常处理和调试技巧;4)使用连接池和限制并发数量来优化性能。 在P…

    2025年12月14日
    000
  • Python微服务架构 Python分布式系统设计原则

    微服务划分应基于业务边界而非技术层次,保持单一职责并提前规划数据归属;通信方式根据场景选择rest、grpc或消息队列;系统设计需处理一致性、容错与监控;工具链如fastapi、celery、docker、consul等能有效支持开发。核心在于理清业务逻辑,合理选型,强化异常处理与协作机制,才能构建…

    2025年12月14日
    000
  • Python爬虫技术入门教程 Python爬虫基础知识点有哪些

    学python爬虫的关键在于掌握核心基础并动手实践。1. 首先要了解http请求与响应机制,包括get/post方法、headers作用及常见状态码,使用requests库发送请求获取数据;2. 掌握html结构解析,利用beautifulsoup或lxml配合css选择器或xpath精准提取所需内…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信