百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

又一个Python调试利器

off999 2024-11-23 20:39 14 浏览 0 评论

简介

在编程过程中,几乎难以避免的会出现错误。事实上,程序员为了消除错误,要花费大量的时间在代码调试上。在调试过程中,使用 print() 语句来理解程序流程和发现意外行为无疑是最常用的方法。

然而,使用 print() 语句存在许多问题,比如

  • print 语句通常用于向用户显示输出。如果程序员使用 print() 进行调试,调试结束后,程序员必须小心地删除仅用于调试的特定 print() 语句。
  • 在调试过程中,可能会连续打印多个变量。在这种情况下,程序员必须手动格式化输出以提高可读性。
  • 当变量数量增加时,可能需要来回查看代码和输出,以确定每个输出对应哪个变量。

幸运的是,python 为我们提供了一个出色的替代方案,icecream。通过使用最少的代码,icecream 使调试变得轻松和可读。

安装

使用 pip 命令安装 icecream

pip install icecream

基本使用

在代码中引入 ic 模块

from icecream import ic

使用 IceCream 库和 print 语句类似,只需将 print 替换为 ic 即可。

from icecream import ic

var1 = 0
var2 = 1.0

ic(var1)
ic(var2)

代码输出

ic| var1: 0
ic| var2: 1.0

注意到了吗?ic() 不仅打印变量的值,还打印变量的名称。

更多应用

icecream 不仅局限于变量,还可以用于函数、类等。

from icecream import ic

def func(num):
    return num * 2

ic(func(3))

代码输出

ic| func(3): 6

太酷了!它打印了方法的名称(func)、传递的参数(3)和输出的值(6)。

python icecream

icecream 的调试功能也适用于常见的 Python 数据结构,比如字典,看下面的例子

from icecream import ic

sample_dict = {1:"A", 2:"B", 3:"C"}

ic(sample_dict[1])

代码输出

ic| sample_dict[1]: 'A'

很多时候,程序员会使用 print() 语句打印一些有意义的语句来确定程序的执行阶段,比如

def func(input_num):
    if input_num == 1:
        print("If Executed!")
        ...

    else:
        print("Else Executed!")
        ...

使用 icecream 可以更优雅的实现目的。

from icecream import ic

def func(input_num):
    if input_num == 1:
        ic()
        ...

    else:
        ic()
        ...

func(2)

只需调用 ic(),它就会打印文件名、行号和其他详细信息(如函数名和时间),非常简单明了,有没有?

接下来,你可能会想,难道每个 Python 文件都需要导入该库吗?答案,当然不必如此!

方法是,在入口文件中导入 icecreaminstall 模块,让所有项目文件都可用,比如

from icecream import install
install()

from help_file import func
func(2)

如果你注意到了,ic() 语句的输出以 "ic|" 开头,这是 icecream 提供的默认前缀。如果有特殊需求,你可以使用 ic.configureOutput() 方法中的 prefix 参数替换默认前缀,看下面示例

from icecream import ic
ic.configureOutput(prefix='ic debug| -> ')

ic("A custom prefix")

代码输出

ic debug| -> 'A custom prefix'

项目一旦调试完成,一般我们希望删除所有不必要的调试语句。可以使用 ic.disable() 停止打印 ic(),如果想再次使用,使用 ic.enable() 即可。

结论

icecreamPython 中一款强大的调试工具,可以更轻松地进行代码调试和错误定位,提高开发效率和代码质量。icecream 是值得每个 Python 程序员掌握和使用的工具之一。

参考资料

  • https://github.com/gruns/icecream

相关推荐

Python开发管理神器--UV 使用教程:从安装到项目管理

UV是一个用Rust编写的高效Python包和项目管理工具,提供了比传统工具更快的速度和更强的功能。本文将指导你如何使用UV从安装到运行一个Python项目。重点:它可以独立安装,可...

python入门-Day 26: 优化与调试(python优化方法)

优化与调试,内容包括处理模型运行中的常见问题(内存、依赖)、调整参数(如最大生成长度),以及练习改进Day25的文本生成结果。我会设计一个结构化的任务,帮助你掌握优化和调试技巧,同时提升模型性能...

Python安装(python安装发生严重错误)

Windows系统1.安装python1.1下载Python安装包打开官方网站:https://www.python.org/downloads/点击"DownloadPython3.1...

UV 上手指南:Python 项目环境/包管理新选择

如果你是一位Python开发者,曾因pipinstall的安装速度而感到沮丧,或者希望Python的依赖管理能够像Node.js那样高效顺滑,那么UV可能正是你所需要的工具。UV...

uv——Python开发栈中的高效全能小工具

每天写Python代码的同学,肯定都离不开pip、virtualenv、Poetry等基础工具,但是对这些工具可能是又恨又离不开。那么有什么好的替代呢,虫虫今天就给大家介绍一个替代他们的小工具uv,一...

使用Refurb让你的Python代码更加优秀

还在担心你写的Python代码是否专业,是否符合规范吗?这里介绍一个Python代码优化库Refurb,使用它可以给你的代码提出更加专业的建议,让你的代码更加的可读,规范和专业。下面简单介绍这个库的使...

【ai】dify+python开发AI八字排盘插件

Dify插件是什么?你可以将Dify插件想象成赋予AI应用增强感知和执行能力的模块化组件。它们使得将外部服务、自定义功能以及专用工具以”即插即用”的简洁方式集成到基于Dify构建的AI...

零基础AI开发系列教程:Dify升级指南

Dify近期发布很是频繁,基本两三天一个版本。值得肯定的是优化和改进了很多问题,但是官方的升级文档有点分散,也有点乱。我这里整理了一个升级文档供大家参考,如果还没有升级到新版本的小伙伴,可以按照我的文...

升级到PyTorch 2.0的技巧总结(如何更新pytorch版本)

来源:DeepHubIMBA本文约6400字,建议阅读12分钟在本文将演示PyTorch2.0新功能的使用,以及介绍在使用它时可能遇到的一些问题。PyTorch2.0发布也有一段时间了,大家...

dify 1.6.0版本发布解读:引入MCP支持与多项核心优化升级指南详解

2025年7月10日,dify发布了1.6.0版本。这是一次功能深度升级与性能优化的综合性更新,标志着dify在技术规范支持、操作体验以及系统稳定性方面迈出了重要的一步。本文将从核心新特性、功能增强、...

Python教程(十四):列表(List)(python列表方法总结)

昨天,我们学习了变量作用域,理解了局部和全局变量的概念。今天,我们将开始探索Python的数据结构,从最常用的**列表(List)**开始。列表是Python中最灵活、最常用的数据结构,它可以存储不同...

Python列表操作(python列表有哪些基本操作)

Python添加列表4分钟阅读在Python操作列表有各种方法。例如–简单地将一个列表的元素附加到for循环中另一个列表的尾部,或使用+/*运算符、列表推导、extend()和i...

Python字符串变形术:replace替换+join连接,10分钟掌握核心操作

字符串替换魔法:replace()实战手册核心价值:一键更新文本内容,精准控制替换范围#基础替换:Python变Javas="hellopython"print(s.re...

python集合set() 数据增册改查统计序循常用方法和数学计算

概念特点定义和创建常用操作集合间的关系集合数学操作集合生成式遍历概念:可变、无序、不重复的序列数据容器特点:无序,不支持下标唯一性,可以删除重复数据可修改定义和创建赋值法:语法:s={x,....

Python列表方法append和extend的区别

在Python编程中,列表是一种非常常用的数据结构。而列表有两个方法append()和extend(),它们看起来有点相似,但实际上有着明显的区别。今天咱们就来好好唠唠这俩方法到底有啥不同。基本区别a...

取消回复欢迎 发表评论: