• Netflix 开源 Polynote:对标 Jupyter,一个笔记本运行多种语言


    谈到数据科学领域的开发工具,Jupyter 无疑是非常知名的一种。它具有灵活高效的特点,非常适合进行开发、调试、分享和教学。近日,Netflix(奈飞)居然也玩起了跨界,他们开源了一个名为 Polynote 的程序。类似于 Jupyter,Polynote 可以进行开发工作,但是能够支持包括 Python 在内的多种编程语言。

    据奈飞在 Medium 的文章中介绍,Polynote 开发的目的是为了给数据科学家和机器学习研究者提供一个笔记本环境,使他们能够自由且无缝地和奈飞本身基于 JVM 的机器学习平台结合。这一平台很大程度上使用的是 Scala 语言,还有一些基于 Python 的机器学习和可视化代码库。Polynote 之前已经在奈飞内部的团队中使用了,现在他们希望将其开源,以促进相关研究的发展。

    Polynote 的五大特性

    据介绍,Polynote 有五个特性值得关注。

    支持多语言

    和 Jupyter Notebook 不同,Polynote 本身支持多种语言编程。除了对 Scala 语言的一级支持,Polynote 还在一个笔记本内支持多语言运行,包括 Scala、Python、SQL 和 Vega,而且这些语言都具备自动补全功能。

    实现多语言支持的是 polyglot。它可以让用户在不同的块中写不同的代码。另外,每个代码块都会接受符合输入名的变量,并返回要求的变量给出下一段代码,不管这些代码是什么样的语言。这样可以让用户按照需要选择某种语言中最合适的工具。

    编辑功能增强

    除了和 Jupyter Notebook 一样可以在代码编辑中插入文本编辑,Polynote 可以很容易地插入 LaTex 公式。

    另外,文本编辑方面有常用的编辑功能。

    运行增强

    在运行的时候,运行的代码块和代码行会显示出来,方便开发者查看运行情况。

    如图所示,Polynote 在运行时会显示当前运行的代码块和代码,以及完成某个任务需要的时间。

    依赖和配置管理

    Polynote 支持对笔记本的依赖和配置进行管理,这样可以避免很多运行时的问题。

     如上图所示,polynote 的配置和依赖管理界面类似于 PyCharm 等高级 IDE,可以自行改变各种依赖的版本和安装方法。和 Jupyter Notebook 不同,这些配置是不需要外部文件或集群服务器进行的。

    数据可视化

    Polynote 和两个非常著名的数据可视化工具进行了结合,它们分别是 Vega 和 Mataplotlib。Polynote 同时也对数据挖掘有着天然支持,这包括数据表视图、表格检查工具、图表构建工具,以及对 Vega 的支持。

     此外,Polynote 还有一些有趣的小特性,如将代码块的位置记录,使得代码库能够按照顺序运行,以保证可复现性。

    安装方法

    目前,Polynote 是一个 notebook 程序,因此用户可以在本地使用,或搭建网络服务。

    首先,用户需要下载这一基于 JVM 的服务器应用(用来提供网络服务代理)。如果要在本地环境下使用,用户可以从开源列表中找到最新版本并下载名为「polynote-dist.tar.gz」的文件(文件可以从 Assets 文件下找到)。

     下载后进入目录,然后进行准备。

    准备内容目前有以下一些:

    • Polynote 只在 OSX 和 Linux 进行了测试,用 Chrome 浏览器进行代理,因此作者们希望用户能够及时反馈意见;

    • 如果用户需要 Spark 支持,则需要安装 Apache Spark;

    • 用户需要使用 Python3,而不是 Python2。

    还有一些其他的依赖,安装代码如下:

     如果要进行配置,用户需要拷贝 config-template.yml 文件到 config.yml 文件中,并取消需要修改的配置上的注释功能。

    运行时,运行以下文件(在下载的文件中):

     在这里我主要是想表达我们一定要边看源码,边通过图例记录下来,深入理解,对你学习很有帮助的。写到这里,感谢阅读!

    给大家分享一个学习群 笔试面试题以及python的进阶学习资料都更新在群里 欢迎大家一起来学习

    点击这里加入该群学习

     

  • 相关阅读:
    TypeScript语法基础
    一个算法题
    唯一数
    webpack5 和 webpack4 的区别有哪些
    支付宝小程序发版
    书‘Rss & Atom in Action’Ch05 中CSHARP示例
    我终于读懂了Handler(二)
    etcdv3与etcdv2特性比较
    axios获取上传进度报错xhr.upload.addEventListener is not a function
    viper读取配置文件
  • 原文地址:https://www.cnblogs.com/heyue0117/p/11905748.html
Copyright © 2020-2023  润新知