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.3-py3-none-any.whl (25.6 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for mpl_chart_styles-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9a3367f69721894cd43ef8e4409e2c90fc106708b7559fb47079fe3c82996c30
MD5 a63efa5d6fd9c8d03376d257d67bb27e
BLAKE2b-256 9da2e2d2d1938ead1d16a4eccafafdd864b38cc43b9cffd6c3c66635a05a75c2

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