JupyterNotebook‘s Magic

举报
Python爱好者 发表于 2020/12/28 22:56:59 2020/12/28
【摘要】 事情的起因是这样子的: 上个星期在看代码的时候,一个意外让我了解到了jupyternotebook上的黑魔法。是这样子的: 这么骚?可以这么玩? 代码上面直接加了个%%time(具体这个百分号是一个还是两个我还没搞清楚,别人敲的是两个,我敲两个就报错,敲一个就OK,具体情况就需要你们在jupyter上试试了),这样可以算出代码的耗时。 我在python上...

640?wx_fmt=png

事情的起因是这样子的:

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

640?wx_fmt=png

这么骚?可以这么玩?

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

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

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

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


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

一个百分号解决问题。

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

640?wx_fmt=png

输出:

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


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

我们来看看:

640?wx_fmt=png

输出结果:

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

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


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


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


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

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

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

640?wx_fmt=png

输出:

640?wx_fmt=png

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

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



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


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

640?wx_fmt=png


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



%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


点击原文可以直达哦!


640?wx_fmt=gif

“希望各位喜欢的可以点个赞!”


文章来源: blog.csdn.net,作者:敲代码的灰太狼,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/tongtongjing1765/article/details/100582060

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。