Skip to main content

An offline exporter for nbconvert.

Project description

nb_offline_convert - An offline exporter for nbconvert

The normal HTML exporter of nbconvert creates the HTML files that will fetch resources (javascript and css files) from CDN, and the WebPDF exporter also depends on HTML exporter, so it's not possible to generate HTML of PDF files with widgets using nbconvert in an environement without internet connection.

This exporter allows nbconvert to export notebooks into HTML and PDF files that use all resources from the local machine by doing three steps:

  • The RequireJS file content is injected directly into the generated HTMLfiles.
  • The ipywidgets javascript file (embed-amd.js), icons and fonts are bundled with nb_offline_convert. embed-amd.js is patched to fetch icons and fonts from local paths instead of CDN
  • The javascript files of widgets are configured to be fetched from the local notebook extension paths.

Installation

nb_offline_convert can be installed from PyPI

pip install nb-offline-convert

Usage

  • Usage in CLI
# convert to html
jupyter nbconvert --to html-offline notebook-you-want-to-convert.ipynb
# convert to pdf
jupyter nbconvert --to webpdf-offline notebook-you-want-to-convert.ipynb

The default Mathjax option is TeX-AMS_CHTML-full,Safe, to change this option, pass --OfflineHTMLExporter.mathjax_option to the command line:

# Use 'TeX-MML-AM_CHTML,Safe' option
jupyter nbconvert --to html-offline --OfflineHTMLExporter.mathjax_option=TeX-MML-AM_CHTML,Safe  notebook-you-want-to-convert.ipynb
  • Usage in a script
from nb_offline_convert import OfflineHTMLExporter, OfflineWebPDFExporter

# convert to html
html_converter = OfflineHTMLExporter()
content, _ = html_converter.from_filename("notebook-you-want-to-convert.ipynb")
with open("converted_file.html", "w") as f:
    f.write(content)
    
# convert to pdf
pdf_converter = OfflineWebPDFExporter()
content, _ = pdf_converter.from_filename("notebook-you-want-to-convert.ipynb")
with open("converted_file.pdf", "wb") as f:
    f.write(content)

Add mathjax_option parameter to the constructor of OfflineHTMLExporter or OfflineWebPDFExporter to modify the Mathjax option:

html_converter = OfflineHTMLExporter(mathjax_option="TeX-AMS_CHTML-full,Safe")

Development

install nb_offline_convert for development using:

git clone https://github.com/trungleduc/nb_offline_convert.git
cd nb_offline_convert
python -m pip install -e .

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nb_offline_convert-0.1.1.tar.gz (5.4 MB view details)

Uploaded Source

Built Distribution

nb_offline_convert-0.1.1-py3-none-any.whl (6.1 MB view details)

Uploaded Python 3

File details

Details for the file nb_offline_convert-0.1.1.tar.gz.

File metadata

  • Download URL: nb_offline_convert-0.1.1.tar.gz
  • Upload date:
  • Size: 5.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/0.0.0 importlib_metadata/4.2.0 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for nb_offline_convert-0.1.1.tar.gz
Algorithm Hash digest
SHA256 e78f3864c1d2a6baf567f4dd1346797efa3586281fbc4aa2fa528de6290ec49f
MD5 7264925ad5a73d8771a011b8539c30c6
BLAKE2b-256 88bbc22becee512ba33c71e789e4071ffc3dc87bbc776c2b3e9b43c0b2eb29ba

See more details on using hashes here.

File details

Details for the file nb_offline_convert-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: nb_offline_convert-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/0.0.0 importlib_metadata/4.2.0 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for nb_offline_convert-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dfc9cae781bd2b8132701d06927966d06047b73c8363ccbba92ee129da1580ae
MD5 a5da2cfb0cfcbed1cc984d372992240b
BLAKE2b-256 36af5c6b646d7e110562277e7e9fa4e9fc4ddcb9c5664215699f03110bffbf80

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page