Jupyter Notebook/Lab
Jupyter Notebook/Lab⚑
(https://jupyter.org/) is an open-source web application that allows you to create and share documents that contain live code, equations, visualizations and narrative text. It can be used for R and for Python, among others.
Tips⚑
Matplotlib⚑
Adjust default plot size⚑
Try running %matplotlib notebook
after the imports.
Extensions⚑
jupyter-server-proxy⚑
(https://jupyter-server-proxy.readthedocs.io/) lets you run arbitrary external processes (such as RStudio, Shiny Server, syncthing, PostgreSQL, etc) alongside your notebook, and provide authenticated web access to them.
Once installed, you'll be able to access arbitrary hosts and ports at <notebook-base>/proxy/<host>:<port>
.
Installation⚑
First, install the required server extension
jupyter serverextension enable --sys-prefix jupyter_server_proxy
then, install the Python package
pip install jupyter-server-proxy
and you're ready to go.
Libraries⚑
jupyter-dash⚑
(https://github.com/plotly/jupyter-dash) is a library that makes it easy to develop Plotly Dash apps interactively from within Jupyter environments.
Installation⚑
pip install jupyter-dash
Usage⚑
In a Jupyter Notebook, run this example application
import plotly.express as px
from jupyter_dash import JupyterDash
JupyterDash.infer_jupyter_proxy_config()
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
## Load Data
df = px.data.tips()
## Build App
app = JupyterDash(__name__)
app.layout = html.Div([
html.H1("JupyterDash Demo"),
dcc.Graph(id='graph'),
html.Label([
"colorscale",
dcc.Dropdown(
id='colorscale-dropdown', clearable=False,
value='plasma', options=[
{'label': c, 'value': c}
for c in px.colors.named_colorscales()
])
]),
])
## Define callback to update graph
@app.callback(
Output('graph', 'figure'),
)
def update_figure(colorscale):
return px.scatter(
df, x="total_bill", y="tip", color="size",
color_continuous_scale=colorscale,
render_mode="webgl", title="Tips"
)
## Run app and display result inline in the notebook
app.run_server(mode='inline')
JupyterDash.infer_jupyter_proxy_config()
is needed if the Jupyter server is not accessible directly, and needs the (#jupyter-server-proxy) extension to be installed.
ipynb⚑
(https://github.com/ipython/ipynb) is a package/module importer for importing code from Jupyter Notebook files (.ipynb).
Usage⚑
To import a Notebook (notebook1
) that is in the same directory as the current one:
import ipynb.fs # Boilerplate required
## Do a full import
from .full.notebook1 import foo
## Do a definitions-only import
from .defs.notebook1 import bar