Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thoth-station/jupyter-nbrequirements
Dependency management and optimization in Jupyter Notebooks
https://github.com/thoth-station/jupyter-nbrequirements
dependency-manager hacktoberfest jupyter jupyter-notebooks notebook package-management
Last synced: 3 months ago
JSON representation
Dependency management and optimization in Jupyter Notebooks
- Host: GitHub
- URL: https://github.com/thoth-station/jupyter-nbrequirements
- Owner: thoth-station
- License: mit
- Created: 2019-06-25T06:48:06.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-29T09:18:17.000Z (over 1 year ago)
- Last Synced: 2024-11-07T11:43:44.964Z (4 months ago)
- Topics: dependency-manager, hacktoberfest, jupyter, jupyter-notebooks, notebook, package-management
- Language: TypeScript
- Homepage:
- Size: 9.53 MB
- Stars: 20
- Watchers: 6
- Forks: 6
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-jupyter-resources - GitHub
README
# jupyter-nbrequirements [data:image/s3,"s3://crabby-images/1add1/1add19aa4a1783902afa0d46a8b5273b01b82103" alt="License"](https://github.com/thoth-station/jupyter-nbrequirements/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/61bba/61bba49d6a440ebf3eda0f4c195ef95f3fbb5971" alt="Dependabot Status"](https://dependabot.com)
[data:image/s3,"s3://crabby-images/37478/374787cb9e6b436ae839d846bd04f5a3ab0af904" alt="Node CI"](https://github.com/cermakm/jupyter-nbrequirements/actions)
[data:image/s3,"s3://crabby-images/36d38/36d3810f31c63d2ba86259d16220a9ef4b6c0852" alt="Release"](https://github.com/thoth-station/jupyter-nbrequirements/releases/latest)Dependency management and optimization in Jupyter Notebooks.
## About
This extension provides control over the notebook dependencies.
The main goals of the project are the following:
- manage notebook requirements without leaving the notebook
- provide a unique and optimized* environment for each notebook*The requirements are optimized using the [Thoth] resolution engine
## Installation
```bash
pip install jupyter-nbrequirements
```And enable the required extensions (might not be needed with the latest version, but to be sure..)
```bash
jupyter nbextension install --user --py jupyter_nbrequirements
```
## Usage
#### NBRequirements UI
Since [v0.4.0](https://github.com/thoth-station/jupyter-nbrequirements/releases/tag/v0.4.0), we've introduced a new UI! Check it out, interact with it and see what it can offer you!
![]()
Our development efforts will from now on focus primarily on improving the UI.
#### The old-school approach
The Jupyter magic is in sync with the UI, so don't worry old schoolers, you can still run the commands manually and the existing notebooks will work!
#### Create the environment for the notebook to run in
Say we want to do an EDA, we will probably need [pandas](https://pandas.pydata.org), a visualization library like [plotly](https://plot.ly) and some additional libraries to make our lives easier, like [sklearn](https://scikit-learn.org/stable/) and [pandas-profiling](https://github.com/pandas-profiling/pandas-profiling).
In a Jupyter notebook cell:
```
%dep add pandas --version ">=0.24.0"
%dep add plotly
%dep add sklearn
%dep add pandas-profiling
```And perhaps our code would need some refactoring and linter checks later on, so let's add a `dev` dependency.
```
%dep add --dev black
```You can now check the requirements that your notebook has by issuing `%requirements` (or `%dep`, which is just an alias for it) command:
```
%requirements
```
```
[packages]
pandas = ">=0.24.0"
plotly = "*"
sklearn = "*"
pandas-profiling = "*"[dev-packages]
black = "*"[[source]]
url = "https://pypi.org/simple"
verify_ssl = true
name = "pypi"[requires]
python_version = "3.6"
```Up to this point, we've been working only with the metadata. In order to create the environment and actually install the dependencies, you run the `%dep ensure` command (insipired by the golang's [dep](https://github.com/golang/dep), for those familiar with Golang).
```
%dep ensure
```> Since this project is still under development and it uses the [Thoth] resolution engine to optimize the notebook dependencies (which is also still under development as well), in case something goes wrong, `ensure` accepts the `engine` parameter, which can be set to `pipenv`
```
%dep ensure --engine pipenv
```Check out the [examples](/examples/) for more info.
## Future plans:
See the [Project Board](https://github.com/thoth-station/jupyter-nbrequirements/projects).
---
> Author: Marek Cermak , @AICoE - Project Thoth
[Thoth]: https://github.com/thoth-station