Skip to main content

Professional presentation-ready chart styles and color palettes for matplotlib

Project description

mpl-presentation-styles

Presentation-quality matplotlib charts in one line.

Stop formatting charts for board meetings. Start presenting.

Install

pip install mpl-presentation-styles

Three ways to use it

1. Quick charts (zero config)

import mpl_presentation_styles as mps

mps.bar({"Q1": 2.5, "Q2": 3.1, "Q3": 2.8, "Q4": 3.6}, title="Revenue ($M)")

2. With your existing matplotlib code (recommended)

import mpl_presentation_styles as mps
import matplotlib.pyplot as plt

mps.apply_palette("boardroom")

# All your existing code just looks better
plt.bar(["Q1", "Q2", "Q3", "Q4"], [2.5, 3.1, 2.8, 3.6])
plt.title("Revenue ($M)")
plt.show()

If you specifically want matplotlib style names, plt.style.use("mps-boardroom") is also supported in many environments, but apply_palette() is the most reliable API across notebook runtimes.

3. Scoped theming

from mpl_presentation_styles import theme, bar

with theme("startup"):
    bar(df, x="Region", y="Revenue", title="Q4 Revenue by Region")
# Previous style is automatically restored

Works with DataFrames

import pandas as pd
import mpl_presentation_styles as mps

df = pd.read_csv("sales.csv")
mps.bar(df, x="Region", y="Revenue", title="Revenue by Region")
mps.line(df, x="Month", y="Growth", title="Monthly Growth Trend")
mps.pie(df, x="Category", y="Share", title="Market Share")

Palettes

Name Style Best For
boardroom Navy/red professional Board decks, executive summaries
startup Purple/green modern Pitch decks, investor updates
classic Muted traditional Academic papers, journal submissions
dashboard High-contrast KPI dashboards, monitoring
print Grayscale Print reports, black & white
warm Amber/orange Marketing, inviting presentations

Smart defaults

  • Auto-register themes: mpl-presentation-styles registers custom themes automatically via a .pth startup hook, so plt.style.use("mps-boardroom") is available immediately after install — no explicit import required.
  • Auto-format values: $1.2M, $450K, $3,750
  • DataFrame-native: Pass column names directly
  • Auto-detect environment: Saves to /mnt/data/ in notebooks, ./ locally
  • Spines removed: Clean, modern look by default
  • 150 DPI: Presentation-ready resolution

Chart types

Function Type DataFrame Dict
mps.bar() Vertical/horizontal bars
mps.line() Trend lines with markers
mps.pie() Pie charts with % labels
mps.scatter() Scatter with annotations

License

MIT

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

mpl_chart_styles-1.0.0-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file mpl_chart_styles-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mpl_chart_styles-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 93b0b38ece20fae034e3763bfb9ba76f55dfb8b9c2889ad5fb70f4b56bc068c9
MD5 361b3d464eb0328a147b93236093bde9
BLAKE2b-256 89dff01c62841d4553b59ce49ade11a2b2d81ddec118338fc9618c1940c80311

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