Apache Zeppelin 中 Python 2&3解释器

配置

属性

默认

描述

zeppelin.python

python

已经安装的Python二进制文件的路径(可以是python2或python3)。如果python不在您的$ PATH中,您可以设置绝对目录(例如:/usr/bin/python)

zeppelin.python.maxResult

1000

要显示的最大数据帧数。

启用Python解释器

在笔记本中,要启用Python解释器,请单击“ 齿轮”图标,然后选择“ Python”

使用Python解释器

在段落中,使用%python选择Python解释器,然后输入所有命令。

解释器只有在已经安装了python的情况下才可以工作(解释器不带自己的python二进制文件)。

要访问帮助,请键入help()

Python环境

默认

默认情况下,PythonInterpreter将使用在zeppelin.python属性中定义的python命令来运行python进程。解释器可以使用已经安装的所有模块(带pip,easy_install ...)

Conda

Conda是一个用于python的软件包管理系统和环境管理系统。 %python.conda解释器可让您在环境之间切换。

用法

列出你的环境

%python.conda

激活环境

%python.conda activate [ENVIRONMENT_NAME]

停用

%python.conda deactivate

Docker

%python.docker 解释器允许PythonInterpreter在指定的docker容器中创建python进程。

用法

激活环境

%python.docker activate [Repository] %python.docker activate [Repository:Tag] %python.docker activate [Image Id]

停用

%python.docker deactivate

案例

# activate latest tensorflow image as a python environment %python.docker activate gcr.io/tensorflow/tensorflow:latest

使用Zeppelin动态表单 

您可以在Python代码中使用Zeppelin 动态表单

Zeppelin动态表单只能在系统中安装py4j Python库时使用。如果没有,可以安装它pip install py4j

示例:

%python ### Input form print (z.input("f1","defaultValue"))    ### Select form print (z.select("f1",[("o1","1"),("o2","2")],"2"))    ### Checkbox form print("".join(z.checkbox("f3", [("o1","1"), ("o2","2")],["1"])))

Matplotlib集成

python解释器可以使用pyplot模块自动显示matplotlib数字:

%python import matplotlib.pyplot as plt plt.plot([1, 2, 3])

这是在Zeppelin笔记本中使用matplotlib的推荐方法。默认情况下,此命令的输出将通过隐式使用%html魔术将其转换为HTML 。使用内置z.configure_mpl()方法可以实现其他配置。例如,

z.configure_mpl(width=400, height=300, fmt='svg') plt.plot([1, 2, 3])

将产生一个SVG格式的400x300图像,默认情况下通常为600x400和PNG。在将来,angular可以使用另一个可选的选项来使从一个段落直接从另一段生成的图形更新(输出将%angular代替%html)。但是,该功能在解释器中已经pyspark可用。更多细节可以在包含的“Zeppelin Tutorial:Python - matplotlib basic”教程笔记本中找到。

如果Zeppelin找不到matplotlib后端文件(通常应该在其中找到$ZEPPELIN_HOME/interpreter/lib/pythonPYTHONPATH,则后端将自动设置为agg,并且(否则不推荐使用)的说明可用于更有限的内联绘图。

如果无法加载内联后端,请使用z.show(plt)python %python import matplotlib.pyplot as plt plt.figure() (.. ..) z.show(plt) plt.close() z.show()功能可以使用可选参数来调整图形尺寸(宽度和高度)以及输出格式(png或可选的svg)。

%python z.show(plt, width='50px') z.show(plt, height='150px', fmt='svg')

Pandas整合

Apache Zeppelin 桌面显示系统 提供内置的数据可视化功能。Python解释器利用它可视化Pandas DataFrames,虽然类似的z.show()API,与Matplotlib集成一样

例:

import pandas as pd rates = pd.read_csv("bank.csv", sep=";") z.show(rates)

在Pandas DataFrames上的SQL

有一个方便的%python.sql解释器,与Zeppelin中的Apache Spark体验相匹配,可以使用SQL语言来查询Pandas DataFrames,并通过内置表格显示系统可视化结果。

预申请

  • Pandas: pip install pandas
  • PandaSQL: pip install -U pandasql

如果默认绑定解释器是Python(首先在解释器列表中,在齿轮图标下),您可以将其用作%sqlie

  • 第一段 import pandas as pd rates = pd.read_csv("bank.csv", sep=";") 
  • 下一段 %sql SELECT * FROM rates WHERE age < 40

否则可以称为 %python.sql

技术说明

有关当前实现的深入技术细节请参考python / README.md

Python解释器中尚未实现某些功能

  • 中断段落执行(cancel()方法)目前仅在Linux和MacOs中受支持。如果解释器在另一个操作系统(例如MS Windows)中运行,则中断一个段落将关闭整个解释器。打开JIRA票(ZEPPELIN-893),在下一个版本的解释器中实现此功能。
  • webUI(getProgress()方法)中的进度条目前尚未实现。
  • 代码完成目前尚未实施。

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏前端知识分享

深入理解Vue的生命周期

  谈到Vue的生命周期,相信许多人并不陌生。但大部分人和我一样,只是听过而已,具体用在哪,怎么用,却不知道。我在学习vue一个多礼拜后,感觉现在还停留在初级阶...

1053
来自专栏大前端_Web

几种方法实现ajax请求内容时使用浏览器后退和前进功能

版权声明:本文为吴孔云博客原创文章,转载请注明出处并带上链接,谢谢。 https://blog.csdn.net/wkyseo/articl...

1422
来自专栏逸鹏说道

Python3 与 C# 并发编程之~ 线程篇2

其实以前的 Linux中是没有线程这个概念的, Windows程序员经常使用线程,这一看~方便啊,然后可能是当时程序员偷懒了,就把进程模块改了改(这就是为什么之...

1634
来自专栏圣杰的专栏

Asp.net mvc 知多少(六)

本系列主要翻译自《ASP.NET MVC Interview Questions and Answers 》- By Shailendra Chauhan,想...

2325
来自专栏大学生计算机视觉学习DeepLearning

VS下如何建立一个新的MFC程序 网络编程 课设 基于C++ MFC 连接数据库 小应用 小项目浅析展示

1733
来自专栏用户2442861的专栏

webStorm 3.0配置使用主题背景色等

http://www.cnblogs.com/jikey/archive/2012/01/16/2323590.html

1271
来自专栏Spark学习技巧

Kafka源码系列之源码解析SimpleConsumer的消费过程

Kafka源码系列是以kafka 0.8.2.2源码为例讲解。浪尖纯属个人爱好,才写想写这个系列。希望对kafka的使用者们带来帮助。 一,消费者消费的过程讲解...

3237
来自专栏大学生计算机视觉学习DeepLearning

网络编程 课设 基于C++ MFC 连接数据库 小应用 小项目浅析展示

3766
来自专栏CRPER折腾记

Angular 2 + 折腾记 :(7) 初步了解表单:模板驱动及数据驱动及脱坑要点

表单在整个系统中的作用相当重要,这里主要扯下响应表单的实现方式。 首先需要操作表单的模块引入这两个模块; import { FormsModule, React...

782
来自专栏Java帮帮-微信公众号-技术文章全总结

springboot 入门教程(5) 基于ssm框架的crud操作(前端部分-附源码)

springboot 入门教程(5) 基于ssm框架的crud操作(前端部分-附源码) 上一篇介绍了spring boot整合mybatis实现了后端的CRUD...

4458

扫码关注云+社区