Skip to main content

Save matplotlib figures as external files and link them, keeping notebooks tiny.

Project description

dietnb (v0.1.2)

PyPI version License: MIT

dietnb addresses the issue of large .ipynb file sizes caused by matplotlib figures being embedded as Base64 data. By saving plots as external PNG files and embedding only image links, dietnb keeps your notebooks lightweight and improves manageability.


Key Features

  • Minimized Notebook Size: Significantly reduces .ipynb file bulk by storing matplotlib figures as external PNG files.
  • Automatic Image Folder Management: Creates and manages image storage directories (e.g., [NotebookFileName]_dietnb_imgs) relative to the notebook's location. (Applies when path detection is successful, e.g., in VS Code; defaults to dietnb_imgs in the current working directory if detection fails.)
  • Automatic Image Updates: When a notebook cell is re-executed, image files generated from its previous run are automatically deleted, ensuring only the latest output is retained.
  • Image Cleanup Function: The dietnb.clean_unused() function allows easy removal of unreferenced image files from the current session.
  • Simple Auto-Activation: The dietnb install command configures dietnb to activate automatically when IPython and Jupyter environments start.

Installation and Activation

1. Install the dietnb package

Execute the following command in your terminal:

pip install dietnb

2. Choose an Activation Method

A. Automatic Activation (Recommended) Run the following command in your terminal once:

dietnb install

After restarting your Jupyter kernel, dietnb will be activated automatically. Images will be saved to a folder based on the notebook's path or to the default dietnb_imgs directory.

B. Manual Activation (Per Notebook) If you prefer to use dietnb only for specific notebooks or do not want automatic activation, add the following code at the top of your notebook to activate it manually:

import dietnb
dietnb.activate()

Example Usage

With dietnb active, use your matplotlib code as usual.

import matplotlib.pyplot as plt
import numpy as np

# Create a plot
x = np.linspace(0, 10, 100)
plt.plot(x, np.sin(x), label='sin(x)')
plt.plot(x, np.cos(x), label='cos(x)')
plt.title("Trigonometric Functions")
plt.xlabel("X-axis")
plt.ylabel("Y-axis")
plt.legend()

plt.show() # On show(), the image is saved to a file, and a link is displayed in the notebook.

Generated images can be found in the [NotebookFileName]_dietnb_imgs folder alongside your notebook, or in the dietnb_imgs folder.


Cleaning Unused Image Files

To remove image files that are no longer in use, execute the following function in a notebook cell:

import dietnb
dietnb.clean_unused()

License

MIT License. See LICENSE for details.


한국어 README (Korean README)

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

dietnb-0.1.2.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dietnb-0.1.2-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file dietnb-0.1.2.tar.gz.

File metadata

  • Download URL: dietnb-0.1.2.tar.gz
  • Upload date:
  • Size: 10.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for dietnb-0.1.2.tar.gz
Algorithm Hash digest
SHA256 b9027b41b2f1af1e4f816b2159ceb5709caa548d8fc3cf19afeee932404084d3
MD5 6ee0f9adac27993c323312c2209cf440
BLAKE2b-256 95ced330625dcca7eec9f63695cacca5fb3dd310880166c95780d18130b96327

See more details on using hashes here.

File details

Details for the file dietnb-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: dietnb-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for dietnb-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3849c3c4af069a001acc4574847ae33e1b8008a51672172b874b534563040ae6
MD5 7e46508185cbabf8edba8a5a29911b4a
BLAKE2b-256 958cb14e7e435c2c2271e1a5ff60c794c326664058af688ac2b7a8288fa16ce2

See more details on using hashes here.

Supported by

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