IceCream in Python

你还在使用print 在Python 中 debug 吗?赶快使用Icecream吧。

提到 Icecream,你是不是会想到ta?

动机

如果你使用print去检查你的code错误时,在你的终端看到很多行的输出时,你可能会很困扰,还要找出哪一个输出对应哪一个code.

例如,运行下面的code:

>>>num1 = 30
>>>num2 = 40 >>>print(num1) #30
>>>print(num2) #40

哪一个输出是num1,哪一个输出是num2, 这两个结果不是很难去分辨,但是如果有超过五种不同的输出那?找出每个code对应的结果可能是很花费时间的?

你可能需要去添加一些文本,以致于打印出来的陈述更容易辨别。

>>>num1 = 30
>>>num2 = 40 >>>print('num1',num1) #num1 30
>>>print('num2',num2) #num2 40

这个结果是很容易发现,但是,它是很费时的去花时间写一些文本,是否有一些其他的方式,不用一些附加的文本反而可以找到code和结果之间的对应关系?

>>>num1 = 30
>>>num2 = 40 >>>ic(num1) # ic| num1
>>>ic(num2) # ic| num2

这就是“冰淇淋”排上用上的时候!

什么是 Icecream

Icecream是一个python的库,可以用最小的代码打印出更多debug的可读信息。

pip install icecream

让我们尝试用它输出一个Python函数

from icecream import ic

def plus_five(num):
return num+5 ic(plus_five(4)) #ic| plus_five(4)=9
ic(plus_five(5)) #ic| plus_five(5)=10

通过使用ic,我们不仅看到了结果,也看到了函数形式和参数。这是多么简洁,在你终端的颜色可以显示出具体参数。

检测执行

为了找出哪一行的code 执行,你可以像下面展示的code这样去找到哪一行被执行。

def hello(user:bool):
if user:
print("I am user")
else:
print("I am not user") hello(user = True)
【output】: I am user

Icecream使得上面这个过程更加简单,通过使用ic(),而不加任何文本就可以实现!

from icecream import ic
# 定义函数
def hello(user:bool):
if user:
ic()
else:
ic() hello(user = True)

现在你可以知道这个code被执行在第五行, 函数是hello 函数,然后第七行的code是不是时候会被执行。

自定义前缀

如果你想嵌入一个自定义前缀,例如时间,这个代码被执行输出成print陈述,icecream也可以让你这么做。

from datetime import datetime
from icecream import ic
import time def time_format():
return f'{datetime.now}|>' ic.configureOutput(prefix = time_format) for _ in range(3):
time.sleep(1)
ic('hello')

现在时间自动被code展现在输出中,这是多么Cool呀!

可以得到更多的信息吗?

除了知道code与输出之间的对应关系,你也可能想知道Code从哪一行,哪一个文件被执行。要是想知道关于code的信息,可以加入includeContext = True ic.configureOutput

from icecream import ic 

def plus_five(num):
return num+5 ic.configureOutput(includeContext = True) ic(plus_five(4))
ic(plus_five(5))

现在你可以知道第一行输出是被第七行的函数plus_five所执行的

完成 Debug 后删除所有的 Icecream

你可以仅仅使用icecreamdebug,而使用print去做其他的事情,例如,很漂亮的输出!

from icecream import ic

def plus_five(num):
return num+5 ic(plus_five(4))
ic(puls_five(5)) for i in range(10):
print("***Traning model{i}***")

由于你可以对debug printpretty print进行区分。在你debug完成后,搜索并删除掉ic语句是更简单的。

删除ic debug后,你的代码看起来更加地简洁。

IceCream in Python的更多相关文章

  1. (数据科学学习手札127)在Python中使用icecream实现高效debug

    本文示例代码及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 尽管有那么多花里胡哨的debug工具和方式 ...

  2. K-近邻算法python实现

    内容主要来源于机器学习实战这本书.加上自己的理解. 1.KNN算法的简单描写叙述 K近期邻(k-Nearest Neighbor.KNN)分类算法能够说是最简单的机器学习算法了. 它採用測量不同特征值 ...

  3. python机器学习实战(一)

    python机器学习实战(一) 版权声明:本文为博主原创文章,转载请指明转载地址 www.cnblogs.com/fydeblog/p/7140974.html  前言 这篇notebook是关于机器 ...

  4. k-近邻(KNN)算法改进约会网站的配对效果[Python]

    使用Python实现k-近邻算法的一般流程为: 1.收集数据:提供文本文件 2.准备数据:使用Python解析文本文件,预处理 3.分析数据:可视化处理 4.训练算法:此步骤不适用与k——近邻算法 5 ...

  5. Python:从入门到实践--第九章-类--练习

    #.餐馆:创建一个名为Restaurant的类,其方法_init_()设置两个属性:restaurant_name和cuisine_type. #创建一个名为describe_restaurant的方 ...

  6. Python机器学习笔记 K-近邻算法

    K近邻(KNN,k-NearestNeighbor)分类算法是数据挖掘分类技术中最简单的方法之一. 所谓K最近邻,就是K个最近的邻居的意思,说的是每个样本都可以用它最接近的k个邻居来代表.KNN算法的 ...

  7. Python编程:从入门到实践(选记)

    本文参考< Python 编程:从入门到实践>一书,作者: [ 美 ] Eric Matthes 第1章 起步 1.1     搭建python环境 在不同的操作系统中, Python 存 ...

  8. Python基础知识:类

    初级篇 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 1.面向对象三大特性 ...

  9. 《Python 数据分析》笔记——pandas

    Pandas pandas是一个流行的开源Python项目,其名称取panel data(面板数据)与Python data analysis(Python 数据分析)之意. pandas有两个重要的 ...

随机推荐

  1. Qt 中的属性系统(Property System)

    21 人赞同了该文章 本节内容主要讲解我对 Qt 属性系统的理解.官方文档参考 The Property System. 如何理解"属性系统"这个概念? 一般我们说一个类有什么属性 ...

  2. 15.SpringMVC之异步请求

    SpringMVC中异步请求相关组件 SpringMVC在此基础上对异步请求进行了封装.提供了AsyncWebRequest类型的request,并提供了处理异步请求的管理器WebAsyncManag ...

  3. 07.SpringMVC之静态资源

    如何你的DispatcherServlet拦截 *.do这样的URL,就不存在访问不到静态资源的问题.如果你的DispatcherServlet拦截"/",拦截了所有的请求,同时对 ...

  4. Web安全-CDN相关技术

    CDN介绍 CDN的全称是Content Delivery Network,即内容分发网络.CDN是构建在现有网络基础之上的智能虚拟网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡.内容分发. ...

  5. FFmpeg 播放 RTSP/Webcam 流

    本文将介绍 FFmpeg 如何播放 RTSP/Webcam/File 流.流程如下: RTSP/Webcam/File > FFmpeg open and decode to BGR/YUV & ...

  6. 老司机带你体验SYS库多种新玩法

    导读 如何更加愉快地利用sys库做一些监控? 快来,跟上老司机,体验sys库的多种新玩法~ MySQL5.7的新特性中,非常突出的特性之一就是sys库,不仅可以通过sys库完成MySQL信息的收集,还 ...

  7. Shell 脚本如何输出帮助信息?

    作者展示了一个技巧,将帮助信息写在 Bash 脚本脚本的头部,然后只要执行"脚本名 + help",就能输出这段帮助信息 https://samizdat.dev/help-mes ...

  8. Kubernetes-Pod介绍(-)

    前言 本篇是Kubernetes第四篇,大家一定要把环境搭建起来,看是解决不了问题的,必须实战.从现在开始都是重要的核心概念,此篇偏一些Pod的概念介绍,后续每篇都会有实战. Kubernetes系列 ...

  9. AWS扩容EC2实例根空间

    文章原文 aws 端操作 先在EC2 实例中选中磁盘 然后打开跟设备 修改大小后保存 ec2 端操作 lsblk 查看当前设备的磁盘编号 df -T -H 查看扩容前的空间大小并确定磁盘格式 grow ...

  10. spring整合jdbc方法一

    用了一段时间的spring这,闲来没事做一下spring整合jdbc 目录文件 导入jar包 由于spring的jar包是在myeclipse中自动导入的有些暂时用不到的也没有处理. Emp类 pac ...