JupyterNotebook‘s Magic

  • 2019 年 10 月 6 日
  • 筆記

事情的起因是这样子的:

上个星期在看代码的时候,一个意外让我了解到了jupyternotebook上的黑魔法。是这样子的:

这么骚?可以这么玩?

代码上面直接加了个%%time(具体这个百分号是一个还是两个我还没搞清楚,别人敲的是两个,我敲两个就报错,敲一个就OK,具体情况就需要你们在jupyter上试试了),这样可以算出代码的耗时。

我在python上试了试,报错,不行,后来去了jupyter上面发现是OK的,也就说这个统计耗时的黑魔法只能在jupyter上运行???

我们一般统计耗时都是使用结束时间减去开始时间的:

st = time.time()  task_mail(self)  end = time.time()  print("任务使用耗时", end - st)

但是有了jupyter后,这一切都变了:

一个百分号解决问题。

如果我们想计算一个循环的耗时,可以这么写:

输出:

CPU times: user 4 ms, sys: 0 ns, total: 4 ms  Wall time: 5.6 ms

除了这个,jupyter还有一个叫timeit的东西,这个东西就更不得了了,它能细算到每一步的耗时!

我们来看看:

输出结果:

3.3 ms ± 171 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)

惊呆了!他能把循环每一步的耗时都清楚的计算出来!!!精确到微秒级!!

但是其实按照结果来看,这两者之间的结果并不一致,这是为什么呢?

大家都知道,python是有垃圾回收机制的,而这个垃圾回收机制是占用耗时的。而timeit()会在计时期间暂时关闭垃圾回收机制,所以耗时也就更短。

%真是神奇,这是为什么呢?

Magic 关键字是可以在单元格中运行的特殊命令,能让你控制 notebook 本身或执行系统调用(例如更改目录)。

又例如,在 notebook 中可以使用 %matplotlib 将 matplotlib 设置为以交互方式工作。

输出:

notebook 允许将图像与文本和代码一起嵌入。在使用 matplotlib 或其他绘图包创建可视化内容时很有用。

在 notebook 中可以使用 %matplotlib 将 matplotlib 设置为以交互方式工作。默认情况下,图形呈现在各自的窗口中。但是,你可以通过命令传递参数,以选择特定的“后端”(呈现图像的软件)。要直接在 notebook 中呈现图形,应将通过命令 %matplotlib inline 内联后端一起使用。

Magic 命令的前面带有一个或两个百分号(% 或 %%),分别对应行 Magic 命令和单元格 Magic 命令。行 Magic 命令仅应用于编写 Magic 命令时所在的行,而单元格 Magic 命令应用于整个单元格。

对于 Python 内核,可以使用 Magic 命令 %pdb

来看看还有哪些其他的%魔法吧!

%alias

为系统命令定义别名。

' %alias alias_name cmd '将' alias_name '定义为' cmd '的别名

然后,输入' alias_name params '将执行系统命令' cmd params '(从您的底层操作系统)。

别名的优先级低于magic函数和Python普通变量,因此如果“foo”既是Python变量又是别名,那么别名在“del foo”删除Python变量之前不能执行。

%autoawait

允许更改自动等待选项的状态。

这允许设置特定的异步代码运行器。

如果没有传递值,请打印当前使用的异步集成以及它是否被激活。

%autocall

使函数可调用,而不必键入括号。

%bookmark

管理IPython的书签系统。

%cd

和shell命令一样,更改当前的工作目录

%conda

安装包使用的(类似于!pip install [pkgs])

%conda install [pkgs]

%debug

激活交互式调试器。

这个神奇的命令支持两种激活调试器的方法。一种是在执行代码之前激活调试器。通过这种方式,您可以设置断点,从该点开始逐步执行代码。可以使用此模式,方法是提供要执行的语句和一个断点。

另一种方法是在死后模式下激活调试器。您可以激活此模式,只需运行%debug而不带任何参数。如果一个异常刚刚发生,这允许您交互式地检查它的堆栈帧。注意,这将始终只在发生的最后一次回溯上工作,所以必须在希望检查的异常触发之后快速调用这个函数,因为如果发生了另一个异常,它会重击前一个异常。

%dirs

返回到当前的目录。

%env

获取或设置环境变量。

还有很多就不一一介绍了,大家可以看看API文档:

https://ipython.readthedocs.io/en/stable/interactive/magics.html#magic-autoawait

点击原文可以直达哦!