专栏首页凹凸玩数据Jupyter Notebook最强指南,没有之一

Jupyter Notebook最强指南,没有之一

Python语言是一种强大而简洁的编程语言。据IEEE Spectrum消息,Python在2020年继续蝉联最受欢迎的编程语言第一名。对于刚接触Python的新手来说,配置一个容易上手又适合自己的开发环境无疑是成功掌握这门编程语言的第一步。对于Python IDE的比较和推荐,各路高手也说法不同,其中被推荐频率最高的当属Pycharm、VS Code和Jupyter Notebook了。

Jupyter Notebook对于Python用户来说想必也不算太陌生。在深度学习领域,吴恩达老师在Cousera上发布的系列课程已经成为公认的入门必学内容。大家可能也注意到了,在《神经网络和深度学习》的第二节课中他专门为学生录制了一个使用Jupyter Notebook的快速指南,并且在很多课程中都通过JupyterNotebook展示代码实现的部分。

这个像笔记本一样又能写文档又能运行代码的工具是怎么来的呢?在Jupyter项目创立之初,创始人Fernando Pérez希望能够在同一个计算工具平台上融合Ju(Julia)、Py(Python)和R这三种科学运算语言的,并且向伽利略发现木星(Jupiter)卫星时所用的笔记本致敬,因此创造了Ju-Py-te-R这个名字。不过经过了五年的发展,现在Jupyter能够支持的语言已经多达四十种,成为一个能够把软件代码、计算输出、解释文档、多媒体资源整合在一起的多功能科学运算平台

看过了吴恩达在Jupyter Notebook上的演示后,你会发现它最大的特点便是可以直接在Web浏览器上编辑和运行,并且允许用户把代码写入独立的单元格中单独执行。这意味着每个格子里都可以编写完马上执行,验证我们的思路是否有问题,并且查看变量的输出情况是否符合预期判断。

如果单元格里的代码有语法错误,运行后在格子下方会直接显示错误提示信息,就像下面这样。由于每个代码块都是单独运行测试的,所以如果查找错误我们也无需从头开始执行代码或者手动增加断点进行调试。这个写代码——运行——确认结果/修改代码——在下一个格子里写代码的过程便称为交互式编程。

Jupyter Notebook提供的交互环境是它的重要功能,也是它在数据分析任务中格外受到欢迎的原因之一。在Notebook中可以方便地调用Python的第三方库,如pandas、Bokeh等,对数据进行清理、统计和可视化的操作,并且在单元格中可以分步输出变量或者绘制图表等等。对于数据分析工程师自身来说,这样既可以验证该步骤中的思路是否有问题,又可以通过输出的直观结果(变量值、图形等)构思后面的步骤怎样执行,极大地提高了任务的整体工作效率。

除了代码之外,你应该也很好奇为什么吴恩达老师的Notebook看起来像一份包含了标题和章节完整讲义吧?这需要归功于JupyterNotebook对Markdown语言的支持。Markdown是一种轻量级标记语言,非常简洁易学,常用于技术文档的写作。基于Markdown语法也衍生出了许多对其功能进行扩展的语法,其中JupyterNotebook使用的是以GitHub为主要风格的GFM语法。

只需要在工具栏中将单元格的格式指定为Markdown,就可以在格子中输入注释、笔记等一切你想要添加的文本,简洁的Markdown语法能帮助你更专注于文本内容。在内容输入完成后运行该单元格,具有格式的文本则会以html的形式显示。另外如果想要上传图片,直接将图片拖拽到Markdown格式的单元格内即可。

掌握了这些功能,你就有机会高效地进行数据分析。同时,在团队沟通和教学展示等环境下,你可以在Jupyter Notebook的界面上快速地复现全部分析过程,并且通过文字叙述、可视化内容、数学公式与代码的整合来降低理解门槛、提高沟通效率。Jupyter Notebook在数据分析场景下的卓越优势是Pycharm、Vim等其他编辑器所无法匹敌的。这种设计思想也来自于文式编程的范式,即在代码中穿插着对代码逻辑的自然语言解释和宏片段,从而使编码者能够以更贴近人类思维习惯的方式进行工作。这种方式特别适用于科学计算和开发开源软件等场景。

Python新手想动手拥有和吴恩达同款的生产工具,可以从这本书开始。《Jupyter Notebook数据分析入门与实战》重点介绍了如何使用JupyterNotebook 进行数据可视化分析,以及自定义Jupyter Notebook、使用云端Jupyter Notebook等一系列实用操作。

这本书对新手的友善度非常高,作者先从Jupyter Notebook的安装和基础操作讲起。读者对照本书一边阅读一边动手实践即可快速入门,Jupyter Notebook中特有的快捷操作和魔术命令也可以一网打尽。

掌握了基本的Notebook操作后我们就可以让代码跑起来了。之后作者依次介绍了使用pandasMatplotlibBokeh三个Python库进行数据分析和可视化的方法,并且根据自己丰富的经验归纳了许多常见问题,比如在绘图时中文出现乱码、输出结果中子图边缘重叠等等。作者针对这些新手上路时常令人苦恼的“坑”给出了详细的解决方法,使刚上手的读者顺利“出坑”从而信心大增。

pandas、Matplotlib和Bokeh都是在数据分析中通用程度高、广受欢迎的Python库,其中许多进阶功能即使是Python和Jupyter Notebook的老用户也不一定掌握,比如绘制特殊图形、合并不同类型图形、设定颜色和颜色映射等等。跟随本书熟练使用这些技巧,就可以在数据分析报告中展示“如何优雅地使用Jupyter Notebook”了。

对于有志于从事科学计算或是数据分析的人员来说,Jupyter Notebook是业界公认的不二之选。这本《Jupyter Notebook数据分析入门与实战》可以成为新手入门之路上的一趟直通车,使你在生产工具上与吴恩达等领军人物并肩。

本文分享自微信公众号 - 凹凸数据(alltodata)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-12-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 从流水线工人到亚马逊数据分析师,坑多路远,10年小结

    10多年前,我大学毕业的那个年代,大部分同学最想做的是产品——那个时候产品改变世界嘛。

    朱小五
  • 爱了!安利一个相见恨晚的可视化学习网站

    最近日常逛逛技术平台,偶然间发现了一个非常牛逼的可视化学习网站。东哥之前在公众号和技术群里也推荐过一些,但和这个相比我觉得真是太逊色了。

    朱小五
  • 各项工具大pk,分组聚合哪家强?

    今天我将带大家分别使用MySQL、Excel、Pandas、VBA和Python来实现这个需求。

    朱小五
  • Jupyter Notebook的安装和使用

    Jupyter Notebook,原名IPython Notbook,是一个开源的WEB应用程序,在WEB端为用户提供交互式的编程体验和服务。名字源自Julia...

    Python碎片公众号
  • Python GIL

    ---- 概述 GIL(Global Interpreter Lock)是什么东东?为什么当一些Pythoners在开发一些多线程操作的时候,都会有些很...

    BrianLv
  • 如何开发自己的搜索帝国之ES图形化Kibana安装与使用

      在如何开发自己的搜索帝国之Elasticsearch中已经介绍安装好了ES,下面就Kibana对ES的查询监控作介绍,就是常提到的大数据日志处理组件ELK里...

    欢醉
  • Python 有可能删除 GIL 吗?

    我们知道,在 CPython 中,有一个全局解释器锁,英文叫 global interpreter lock,简称 GIL,是一个互斥锁,用来保护 Python...

    somenzz
  • Python Web学习笔记之为什么设计GIL

    GIL(global interpreter lock),全局解释器锁,是很多编程语言实现中都具有的特性,由于它的存在,解释器无法实现真正的并发。它也是 Pyt...

    Jetpropelledsnake21
  • 机器学习新手必看:Jupyter Notebook入门指南

    【导读】Jupyter Notebook 是一个 Web 应用程序,便于创建和共享文学化程序文档,支持实时代码、数学方程、可视化和 Markdown,其用途包括...

    IT派
  • Kibana,Grafana——错误猎手,系统定海神针

    开发程序出现错误是一件很正常的事,即使有经验的程序员也是如此,关键是要及时发现并定位错误。

    用户2781897

扫码关注云+社区

领取腾讯云代金券