Publication-ready plotting with a clean, modular API
Project description
PubliPlots
Publication-ready plots
Overview
PubliPlots is a Python visualization library that provides beautiful, publication-ready plots with a seaborn-like API. It focuses on:
- Beautiful defaults: Carefully designed pastel color palettes and styles
- Intuitive API: Follows seaborn conventions for ease of use
- Modular design: Compose complex visualizations from simple building blocks
- Highly configurable: Extensive customization while maintaining sensible defaults
- Publication-ready: Optimized for scientific publications and presentations
[!IMPORTANT] Documentation: Full documentation is available at jorgebotas.github.io/publiplots
Claude Code plugin
[!TIP]
Using Claude Code? Install the publiplots plugin to teach Claude idiomatic publiplots (mm-units layout,
pp.subplots, unifiedpp.legendscoping) in one command.
/plugin marketplace add jorgebotas/publiplots
/plugin install publiplots@publiplots
The plugin ships two skills that auto-activate when Claude detects publiplots work:
/publiplots:publiplots-guide— library conventions, fullpp.*API surface, canonical idioms, common gotchas./publiplots:legend-placement— decision tree forpp.legendscoping (per-axes, row/column bands, figure-level bands) plus thepp.legend(ax)vspp.legend(anchor=ax)asymmetry.
Example usage
Once installed, asking Claude natural-language questions produces idiomatic publiplots code:
"Make a 2×3 scatter grid with a shared legend above the top row."
Claude will auto-invoke legend-placement and produce something like:
import publiplots as pp
fig, axes = pp.subplots(2, 3, axes_size=(35, 25))
for ax in axes.flat:
pp.scatterplot(data=df, x='x', y='y', hue='group', ax=ax)
pp.legend(axes[0], side='top') # row-0 shared band
pp.savefig('figure.pdf')
You can also invoke skills explicitly with /publiplots:publiplots-guide or /publiplots:legend-placement at any time. Plugin versions track library releases; pin a specific release with @v0.10.1.
Gallery
For interactive examples, check out the examples.ipynb notebook.
Installation
From PyPI
pip install publiplots
Or if you are using uv for Python environment management:
uv pip install publiplots
From source (development)
git clone https://github.com/jorgebotas/publiplots.git
cd publiplots
pip install -e .
Development with uv and Jupyter
If you're using uv for Python environment management and want to use the package in Jupyter notebooks:
# Clone the repository
git clone https://github.com/jorgebotas/publiplots.git
cd publiplots
# Create a new uv environment with Python 3.11 (or your preferred version)
uv venv --python 3.11
# Activate the environment
source .venv/bin/activate # On Linux/macOS
# or
.venv\Scripts\activate # On Windows
# Install the package in editable mode with all dependencies
uv pip install -e .
# Install ipykernel to make the environment available in Jupyter
uv pip install ipykernel
# Register the environment as a Jupyter kernel
python -m ipykernel install --user --name=publiplots --display-name="Python (publiplots)"
Now you can select the "Python (publiplots)" kernel in Jupyter Lab or Jupyter Notebook and import publiplots:
import publiplots as pp
Quick Start
import publiplots as pp
import pandas as pd
# Apply publication style globally
pp.set_publication_style()
# Create a scatter plot
ax = pp.scatterplot(
data=df,
x='measurement_a',
y='measurement_b',
hue='condition',
palette=pp.color_palette('pastel', n_colors=3)
)
# Save with publication-ready settings
pp.savefig('figure.pdf')
Matplotlib backends
publiplots is backend-agnostic — every plot works under any
matplotlib backend (PNG/JPG via Agg, PDF, SVG, PS, interactive
Jupyter inline / widget, desktop GUIs). The library never calls
matplotlib.use(...) implicitly, so it won't override a backend you've
already picked.
For headless rendering (scripts, CI, notebooks without displays) the common pattern is to set Agg in your own code before importing pyplot:
import matplotlib
matplotlib.use("Agg") # must come before pyplot touches the GUI
import matplotlib.pyplot as plt
import publiplots as pp
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
Citation
If you use PubliPlots in your research, please cite:
Botas, J. (2025). PubliPlots: Publication-ready plotting for Python.
GitHub: https://github.com/jorgebotas/publiplots
License
MIT License - see LICENSE file for details.
Author
Jorge Botas (@jorgebotas)
Acknowledgments
PubliPlots builds upon excellent work from the Python visualization community:
- ggvenn by Yan Linlin - The Venn diagram implementation (2-5 sets) is based on the geometry from this R package
- UpSetPlot by Joel Nothman - The UpSet plot implementation is inspired by concepts from this library (BSD-3-Clause license)
- matplotlib - The foundational plotting library that powers PubliPlots
- seaborn - Inspiration for API design and color palettes
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file publiplots-0.10.1.tar.gz.
File metadata
- Download URL: publiplots-0.10.1.tar.gz
- Upload date:
- Size: 1.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3c0216032927cbdd44a1e517fe09b5cda5e736f87faefd45d81552d9b43fd1be
|
|
| MD5 |
ce17cccd1996cb3ee354ed464bfd93ca
|
|
| BLAKE2b-256 |
f40caf8000104452a0251e9cdbea5350cb76441f9aec71a63969bd341d281173
|
Provenance
The following attestation bundles were made for publiplots-0.10.1.tar.gz:
Publisher:
publish.yml on jorgebotas/publiplots
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
publiplots-0.10.1.tar.gz -
Subject digest:
3c0216032927cbdd44a1e517fe09b5cda5e736f87faefd45d81552d9b43fd1be - Sigstore transparency entry: 1464847735
- Sigstore integration time:
-
Permalink:
jorgebotas/publiplots@2f1d88b78e83f25e2d5b95ce2b086d7d14e05220 -
Branch / Tag:
refs/tags/v0.10.1 - Owner: https://github.com/jorgebotas
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2f1d88b78e83f25e2d5b95ce2b086d7d14e05220 -
Trigger Event:
release
-
Statement type:
File details
Details for the file publiplots-0.10.1-py3-none-any.whl.
File metadata
- Download URL: publiplots-0.10.1-py3-none-any.whl
- Upload date:
- Size: 1.1 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18b3ac98c47ed156ec7e19ac616ca978ddf7c7a0526fd9214a02e68bec8349cb
|
|
| MD5 |
b6adbc29ec3c08f186961b808a4ae040
|
|
| BLAKE2b-256 |
3c60af5fbdc9d0c2e2d49e2ede97db8e5313451231297fd3d8da19ed3d746803
|
Provenance
The following attestation bundles were made for publiplots-0.10.1-py3-none-any.whl:
Publisher:
publish.yml on jorgebotas/publiplots
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
publiplots-0.10.1-py3-none-any.whl -
Subject digest:
18b3ac98c47ed156ec7e19ac616ca978ddf7c7a0526fd9214a02e68bec8349cb - Sigstore transparency entry: 1464847862
- Sigstore integration time:
-
Permalink:
jorgebotas/publiplots@2f1d88b78e83f25e2d5b95ce2b086d7d14e05220 -
Branch / Tag:
refs/tags/v0.10.1 - Owner: https://github.com/jorgebotas
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2f1d88b78e83f25e2d5b95ce2b086d7d14e05220 -
Trigger Event:
release
-
Statement type: