IceCream in Python

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

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

动机

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

例如,运行下面的code:

  1. >>>num1 = 30
  2. >>>num2 = 40
  3. >>>print(num1) #30
  4. >>>print(num2) #40

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

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

  1. >>>num1 = 30
  2. >>>num2 = 40
  3. >>>print('num1',num1) #num1 30
  4. >>>print('num2',num2) #num2 40

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

  1. >>>num1 = 30
  2. >>>num2 = 40
  3. >>>ic(num1) # ic| num1
  4. >>>ic(num2) # ic| num2

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

什么是 Icecream

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

  1. pip install icecream

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

  1. from icecream import ic
  2. def plus_five(num):
  3. return num+5
  4. ic(plus_five(4)) #ic| plus_five(4)=9
  5. ic(plus_five(5)) #ic| plus_five(5)=10

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

检测执行

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

  1. def hello(user:bool):
  2. if user:
  3. print("I am user")
  4. else:
  5. print("I am not user")
  6. hello(user = True)
  1. output】: I am user

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

  1. from icecream import ic
  2. # 定义函数
  3. def hello(user:bool):
  4. if user:
  5. ic()
  6. else:
  7. ic()
  8. hello(user = True)

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

自定义前缀

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

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

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

可以得到更多的信息吗?

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

  1. from icecream import ic
  2. def plus_five(num):
  3. return num+5
  4. ic.configureOutput(includeContext = True)
  5. ic(plus_five(4))
  6. ic(plus_five(5))

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

完成 Debug 后删除所有的 Icecream

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

  1. from icecream import ic
  2. def plus_five(num):
  3. return num+5
  4. ic(plus_five(4))
  5. ic(puls_five(5))
  6. for i in range(10):
  7. 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. DataTable 读取每一行的内容

    foreach (DataRow item in dataTable.Rows) { for (int i = 0; i < dataTable.Columns.Count; i++) { Co ...

  2. jsoup的Document类

    一.简介 Document是一个装载html的文档类,它是jsoup一个非常重要的类.类声明:public class Document extends Element .Document是Node间 ...

  3. C#中Finalize方法的问题

    ninputer在关于"值类型的Finalize不会被调用"中(http://blog.joycode.com/lijianzhong/archive/2005/01/13/429 ...

  4. JavaWeb之数据库连接池

    时间:2016-12-2 23:56 --DBCP连接池连接池参数(所有连接池参数都有默认值):    初始大小    最小空闲连接数    增量    最大空闲连接数    最大连接数    最长等 ...

  5. etcd学习(7)-etcd中的线性一致性实现

    线性一致性 CAP 什么是CAP CAP的权衡 AP wihtout C CA without P CP without A 线性一致性 etcd中如何实现线性一致性 线性一致性写 线性一致性读 1. ...

  6. 微信小程序 转盘抽奖 倒计时 整点

    xml: <view id="luckdraw_box"> <view id="luckdraw_back"> <image st ...

  7. shutdown 命令

    # shutdown -h #停止系统服务并关机 -r #停止系统服务后重启 shutdown -h now #立即关机 shutdown -h 10:53 #到10:53关机,如果该时间小于当前时间 ...

  8. [考试总结]noip模拟43

    这个题目出的还是很偷懒.... 第一题...第二题...第三题...四.... 好吧... 这几次考得都有些问题,似乎可能是有些疲惫,脑袋也是转不太动,考完总觉得自己是能力的问题,但是改一分钟之后会发 ...

  9. springcloud3(五) spring cloud gateway动态路由的四类实现方式

    写这篇博客主要是为了汇总下动态路由的多种实现方式,没有好坏之分,任何的方案都是依赖业务场景需求的,现在网上实现方式主要有: 基于Nacos, 基于数据库(PosgreSQL/Redis), 基于Mem ...

  10. Configuration对象和SessionFactory会话池

    一.加载核心配置文件方式 二.加载映射文件方式 三.SessionFactory相当于连接池 四.获取session会话 同一个线程中获取的session两种方法获取的是同一个session对象: 不 ...