Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samlau95/nbinteract
Create interactive webpages from Jupyter Notebooks
https://github.com/samlau95/nbinteract
interactive-webpages ipywidgets jupyter-notebook notebook python3
Last synced: 7 days ago
JSON representation
Create interactive webpages from Jupyter Notebooks
- Host: GitHub
- URL: https://github.com/samlau95/nbinteract
- Owner: SamLau95
- License: bsd-3-clause
- Created: 2017-08-31T00:16:20.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-02-13T21:24:04.000Z (11 months ago)
- Last Synced: 2025-01-04T00:17:37.769Z (7 days ago)
- Topics: interactive-webpages, ipywidgets, jupyter-notebook, notebook, python3
- Language: HTML
- Homepage: http://www.samlau.me/nbinteract/
- Size: 26.4 MB
- Stars: 235
- Watchers: 7
- Forks: 22
- Open Issues: 66
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
‼️ `nbinteract` is an old research project and is no longer actively maintained. Try https://github.com/voila-dashboards/voila instead. ‼️
nbinteract
=================[![Read the Docs](https://img.shields.io/badge/docs-nbinteract.com-green.svg)][docs]
[![Gitter](https://badges.gitter.im/owner/repo.png)][gitter][![Build Status](https://travis-ci.org/SamLau95/nbinteract.svg?branch=master)](https://travis-ci.org/SamLau95/nbinteract)
[![PyPI](https://img.shields.io/pypi/v/nbinteract.svg)](https://pypi.python.org/pypi/nbinteract/)
[![npm](https://img.shields.io/npm/v/nbinteract.svg)](https://www.npmjs.com/package/nbinteract)`nbinteract` is a Python package that creates interactive webpages from Jupyter
notebooks. `nbinteract` also has built-in support for interactive plotting.
These interactions are driven by data, not callbacks, allowing authors to focus
on the logic of their programs.`nbinteract` is most useful for:
- Data scientists that want to create simple interactive blog posts without having
to know / work with Javascript.
- Instructors that want to include interactive examples in their textbooks.
- Students that want to publish data analysis that contains interactive demos.Currently, `nbinteract` is in an alpha stage because of its quickly-changing
API.## Examples
Most plotting functions from other libraries (e.g. `matplotlib`) take data as
input. `nbinteract`'s plotting functions take functions as input.```python
import numpy as np
import nbinteract as nbidef normal(mean, sd):
'''Returns 1000 points drawn at random fron N(mean, sd)'''
return np.random.normal(mean, sd, 1000)# Pass in the `normal` function and let user change mean and sd.
# Whenever the user interacts with the sliders, the `normal` function
# is called and the returned data are plotted.
nbi.hist(normal, mean=(0, 10), sd=(0, 2.0), options=options)
```![example1](https://github.com/SamLau95/nbinteract/raw/master/docs/images/example1.gif)
Simulations are easy to create using `nbinteract`. In this simulation, we roll
a die and plot the running average of the rolls. We can see that with more
rolls, the average gets closer to the expected value: 3.5.```python
rolls = np.random.choice([1, 2, 3, 4, 5, 6], size=300)
averages = np.cumsum(rolls) / np.arange(1, 301)def x_vals(num_rolls):
return range(num_rolls)# The function to generate y-values gets called with the
# x-values as its first argument.
def y_vals(xs):
return averages[:len(xs)]nbi.line(x_vals, y_vals, num_rolls=(1, 300))
```![example2](https://github.com/SamLau95/nbinteract/raw/master/docs/images/example2.gif)
## Publishing
From a notebook cell:
```python
# Run in a notebook cell to convert the notebook into a publishable HTML page:
#
# nbi.publish('my_binder_spec', 'my_notebook.ipynb')
#
# Replace my_binder_spec with a Binder spec in the format
# {username}/{repo}/{branch} (e.g. SamLau95/nbinteract-image/master).
#
# Replace my_notebook.ipynb with the name of the notebook file to convert.
#
# Example:
nbi.publish('SamLau95/nbinteract-image/master', 'homepage.ipynb')
```From the command line:
```bash
# Run on the command line to convert the notebook into a publishable HTML page.
#
# nbinteract my_binder_spec my_notebook.ipynb
#
# Replace my_binder_spec with a Binder spec in the format
# {username}/{repo}/{branch} (e.g. SamLau95/nbinteract-image/master).
#
# Replace my_notebook.ipynb with the name of the notebook file to convert.
#
# Example:
nbinteract SamLau95/nbinteract-image/master homepage.ipynb
```For more information on publishing, see the [tutorial][] which has a complete
walkthrough on publishing a notebook to the web.## Installation
Using `pip`:
```bash
pip install nbinteract# The next two lines can be skipped for notebook version 5.3 and above
jupyter nbextension enable --py --sys-prefix widgetsnbextension
jupyter nbextension enable --py --sys-prefix bqplot
```You may now import the `nbinteract` package in Python code and use the
`nbinteract` CLI command to convert notebooks to HTML pages.## Tutorial and Documentation
[Here's a link to the tutorial and docs for this project.][docs]
## Developer Install
If you are interested in developing this project locally, run the following:
```
git clone https://github.com/SamLau95/nbinteract
cd nbinteract# Installs the nbconvert exporter
pip install -e .# To export a notebook to interactive HTML format:
jupyter nbconvert --to interact notebooks/Test.ipynbpip install -U ipywidgets
jupyter nbextension enable --py --sys-prefix widgetsnbextensionbrew install yarn
yarn install# Start notebook and webpack servers
make -j2 serve
```## Feedback
If you have any questions or comments, send us a message on the
[Gitter channel][gitter]. We appreciate your feedback!## Contributors
`nbinteract` is originally developed by [Sam Lau][sam] and Caleb Siu as part of
a Masters project at UC Berkeley. The code lives under a BSD 3 license and we
welcome contributions and pull requests from the community.[tutorial]: /tutorial/tutorial_getting_started.html
[ipywidgets]: https://github.com/jupyter-widgets/ipywidgets
[bqplot]: https://github.com/bloomberg/bqplot
[widgets]: http://jupyter.org/widgets.html
[gh-pages]: https://pages.github.com/
[gitbook]: http://gitbook.com/
[install-nb]: http://jupyter.readthedocs.io/en/latest/install.html
[docs]: https://www.nbinteract.com/
[sam]: http://www.samlau.me/
[gitter]: https://gitter.im/nbinteract/Lobby/