Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paw-lu/nbpreview
A terminal viewer for Jupyter notebooks. It's like cat for ipynb files.
https://github.com/paw-lu/nbpreview
Last synced: 3 months ago
JSON representation
A terminal viewer for Jupyter notebooks. It's like cat for ipynb files.
- Host: GitHub
- URL: https://github.com/paw-lu/nbpreview
- Owner: paw-lu
- License: mit
- Created: 2021-03-18T03:05:18.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-03-28T16:17:50.000Z (almost 2 years ago)
- Last Synced: 2024-11-07T11:49:52.348Z (3 months ago)
- Language: Python
- Homepage: https://nbpreview.readthedocs.io/
- Size: 5.01 MB
- Stars: 168
- Watchers: 5
- Forks: 7
- Open Issues: 40
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/6d959/6d9590a8e71f0003ae2ec95c35254678b1c70917" alt="nbpreview light logo"
data:image/s3,"s3://crabby-images/bcb3d/bcb3d513cc4752cfd04434e42077cb8b306ac0b8" alt="nbpreview dark logo"# nbpreview
[data:image/s3,"s3://crabby-images/ae90a/ae90a1b17cdb458fe3d891a0e5eca828a68a1e69" alt="Checked with mypy"](http://mypy-lang.org/)
[data:image/s3,"s3://crabby-images/25246/25246f9a33cae990b38d12417e77adde253c4114" alt="PyPI"](https://pypi.org/project/nbpreview/)
[data:image/s3,"s3://crabby-images/810bd/810bd96d9805d93efd7b685cae91058c84f05c6f" alt="Status"](https://pypi.org/project/nbpreview/)
[data:image/s3,"s3://crabby-images/786de/786ded0395d121a3a2f09c46ee6c200c469a6672" alt="Python Version"](https://pypi.org/project/nbpreview)
[data:image/s3,"s3://crabby-images/b73bf/b73bf69f7cb4d4839c2d009c7fbce535e8e861b9" alt="License"](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/87e2b/87e2bbf567267da1727b3c6a823f3ceb2bf24341" alt="Read the documentation at https://nbpreview.readthedocs.io/"][documentation]
[data:image/s3,"s3://crabby-images/df826/df826252d82a99c6b787047fdd80630af04322bc" alt="Tests"](https://github.com/paw-lu/nbpreview/actions?workflow=Tests)
[data:image/s3,"s3://crabby-images/f8df6/f8df64c04e090befaaac856c74e84a97f653982e" alt="Codecov"](https://codecov.io/gh/paw-lu/nbpreview)
[data:image/s3,"s3://crabby-images/65ea5/65ea56a782a92978a9d1c30ea7b56b2bd4e42d2a" alt="pre-commit"](https://github.com/pre-commit/pre-commit)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Black"](https://github.com/psf/black)
[data:image/s3,"s3://crabby-images/2b8ac/2b8ac0b40688968d026c257731b2e37213f350f1" alt="Imports: isort"](https://pycqa.github.io/isort/)
[data:image/s3,"s3://crabby-images/d3868/d38687124456935c3cb2c405abeec2715b9372f9" alt="security: bandit"](https://github.com/PyCQA/bandit)A terminal viewer for Jupyter notebooks.
It's like [cat](https://man7.org/linux/man-pages/man1/cat.1.html) for ipynb files.[documentation]: https://nbpreview.readthedocs.io/
data:image/s3,"s3://crabby-images/d3c61/d3c6127e92586fd53504253ef809051f843cb766" alt="Hero image"
## Documentation
nbpreview's [documentation] contains
a detailed breakdown of its [features],
[command-line usage][usage],
and [instructions on how to configure][configure] the tool.## Requirements
- Python 3.8+
## Installation
nbpreview can be installed through [pipx] or [pip] from [PyPI](https://pypi.org/).
[pipx] provides an easy way to install Python applications in isolated environments.
[See the documentation for how to install pipx.](https://pypa.github.io/pipx/installation/#install-pipx)```console
% pipx install nbpreview
```If [pipx] is not installed,
nbpreview may also be installed via [pip]:```console
% python -m pip install nbpreview
```[pipx]: https://pypa.github.io/pipx/
[pip]: https://pip.pypa.io/## Features
### [Syntax highlight code cells](https://nbpreview.readthedocs.io/en/latest/features.html#syntax-highlighting)
data:image/s3,"s3://crabby-images/02c79/02c794f02e2eb4139c1562570e59249081076a7f" alt="Material theme syntax highlighting"
### [Render markdown](https://nbpreview.readthedocs.io/en/latest/features.html#markdown-rendering)
data:image/s3,"s3://crabby-images/7e54d/7e54d048c15493181108d36a979de5449d88f2e6" alt="Markdown render"
### [Draw images](https://nbpreview.readthedocs.io/en/latest/features.html#images)
data:image/s3,"s3://crabby-images/ca7ec/ca7ece89d5783b7231cefa50af267a79724ae73a" alt="Block drawing of image"
### [Render DataFrame](https://nbpreview.readthedocs.io/en/latest/features.html#dataframe-rendering)
data:image/s3,"s3://crabby-images/bd506/bd506253e8906f46494f09b7ce31882b37420566" alt="DataFrame render"
### [Create previews for Vega charts](https://nbpreview.readthedocs.io/en/latest/features.html#vega-and-vegalite-charts)
data:image/s3,"s3://crabby-images/ad499/ad499a1309d7a31fd46872f5a907b09199fb8c9f" alt="DataFrame render"
### [Render LaTeX](https://nbpreview.readthedocs.io/en/latest/features.html#latex)
data:image/s3,"s3://crabby-images/3040b/3040b72e138a88f5a5640c1c9b64b84611d4085a" alt="LaTeX render"
### [Parse HTML](https://nbpreview.readthedocs.io/en/latest/features.html#html)
data:image/s3,"s3://crabby-images/1d8dd/1d8dd8c25e2632041f5f0f807fcb36ee1865593a" alt="HTML render"
### [Create hyperlinks for complex content](https://nbpreview.readthedocs.io/en/latest/features.html#hyperlinks)
data:image/s3,"s3://crabby-images/4259e/4259e167801beed13d36b268cde167194907319d" alt="Hyperlink renders"
### [Render stderr output](https://nbpreview.readthedocs.io/en/latest/features.html#stderr)
data:image/s3,"s3://crabby-images/97f1e/97f1e465eb88d16d64b086b74612323cc3dd86d3" alt="Stderr render"
### [Render tracebacks](https://nbpreview.readthedocs.io/en/latest/features.html#tracebacks)
data:image/s3,"s3://crabby-images/b3e8a/b3e8a32a62da8d4f8f5d0c7477cbfaabb2c9b792" alt="Traceback render"
### [Use Nerd Font icons](https://nbpreview.readthedocs.io/en/latest/features.html#nerd-fonts)
## Try it out
Assuming [curl] and [pipx] are installed,
nbpreview may be tried out on the terminal by running:```console
% curl https://raw.githubusercontent.com/paw-lu/nbpreview/main/docs/example_notebook_cells/hero_notebook.ipynb | pipx run nbpreview
```## Usage
To use nbpreview,
type `nbpreview` into your terminal followed by the path of the notebook you wish to view.```console
% nbpreview notebook.ipynb
```See the [command-line reference][usage] for details on options.
## Contributing
Contributions are very welcome.
To learn more, see the [contributor guide][contributing].## License
Distributed under the terms of the [MIT license][license],
_nbpreview_ is free and open source software.## Issues
If you encounter any problems,
please [file an issue][issues] along with a detailed description.## Prior art
### Similar tools
Thanks to [@joouha] for [maintaining a list of these tools][euporie_similar_tools].
Many of the projects here were found directly on their page.- [ipynb-term](https://github.com/PaulEcoffet/ipynbviewer)
- [ipynbat](https://github.com/edgarogh/ipynbat)
- [ipynbviewer](https://github.com/edgarogh/ipynbat)
- [jcat](https://github.com/ktw361/jcat)
- [jupview](https://github.com/Artiomio/jupview)
- [jupytui](https://github.com/mosiman/jupytui)
- [jut](https://github.com/kracekumar/jut)
- [nbcat](https://github.com/jlumpe/nbcat)
- [nbtui](https://github.com/chentau/nbtui)
- [nbv](https://github.com/lepisma/nbv)
- [Read-Jupyter-Notebook](https://github.com/qcw171717/Read-Jupyter-Notebook)[@joouha]: https://github.com
[euporie_similar_tools]: https://euporie.readthedocs.io/en/latest/pages/related.html#notebook-viewers### Complimentary tools
If you're interested in complimentary tools
that help improve the terminal experience for notebooks,
there are many amazing projects out there.- **[bat](https://github.com/sharkdp/bat)**
is not a tool for notebooks specifically.
But similar to nbpreview,
it provides a rich output for many types of files on the terminal,
and is the primary inspiration for nbpreview.
- **[euporie]**
is a really exciting project
that allows you to edit and run Jupyter notebooks on the terminal.
- **[nbclient]**
is a library for executing notebooks from the command line.
- **[nbpreview]**
is another project that coincidentally shares a name with this one.
It allows for Jupyter notebooks to be rendered
without running a notebook server.
- **[nbqa]**
allows the use of linters and formatters on notebooks.
It's also used by this project.
- **[jpterm]**
is and up-and-coming successor to [nbterm]
which will be accompanied by a web client.
Looking forward to seeing this develop.
- **[nbtermix]**
is an actively-developed fork of [nbterm].
- **[nbterm]**
lets you edit and execute Jupyter Notebooks on the terminal.
- **[papermill]**
allows the parameterization and execution of Jupyter Notebooks.[nbterm]: https://github.com/davidbrochart/nbterm
[euporie]: https://github.com/joouha/euporie
[nbclient]: https://github.com/jupyter/nbclient
[nbpreview]: https://github.com/jsvine/nbpreview
[nbqa]: https://github.com/nbQA-dev/nbQA
[jpterm]: https://github.com/davidbrochart/jpterm
[nbtermix]: https://github.com/mtatton/nbtermix
[papermill]: https://github.com/nteract/papermill## Credits
nbpreview relies on a lot of fantastic projects.
Check out the [dependencies] for a complete list of libraries that are leveraged.Besides the direct dependencies,
there are some other projects that directly enabled the development of nbpreview.- **[bat]**
is not explicitly used in this project,
but served as the primary inspiration.
This projects strives to be [bat]—but
for notebooks.
Many of nbpreview's features and command-line options are directly adopted from [bat].
- **[Hypermodern Python Cookiecutter]**
is the template this project was generated on.
It is a fantastic project that integrates [Poetry],
[Nox],
and [pre-commit].
It's responsible for most of this project's CI.
- **[justcharts]**
is directly used by this project
to generate the Vega and Vega-Lite charts.[bat]: https://github.com/sharkdp/bat
[hypermodern python cookiecutter]: https://github.com/cjolowicz/cookiecutter-hypermodern-python
[justcharts]: https://github.com/koaning/justcharts
[nox]: https://nox.thea.codes/en/stable/
[poetry]: https://python-poetry.org/
[pre-commit]: https://pre-commit.com/[configure]: https://nbpreview.readthedocs.io/configure.html
[contributing]: https://github.com/paw-lu/nbpreview/blob/main/CONTRIBUTING.md
[curl]: https://curl.se/docs/
[dependencies]: https://github.com/paw-lu/nbpreview/blob/main/pyproject.toml
[exporting_rich_console]: https://rich.readthedocs.io/en/stable/console.html#exporting
[features]: https://nbpreview.readthedocs.io/features.html
[furo]: https://pradyunsg.me/furo/quickstart/
[issues]: https://github.com/paw-lu/nbpreview/issues
[license]: https://opensource.org/licenses/MIT
[myst]: https://myst-parser.readthedocs.io/en/latest/
[usage]: https://nbpreview.readthedocs.io/en/latest/usage.html