Skip to main content

A fluent wrapper around matplotlib for easy, expressive visualizations

Project description

Tests Lint & Format Tested PyPI Version Dependencies Status Docs (latest)

mplviz

Viz - A Fluent API Wrapper for Matplotlib

Viz is a user-friendly, fluent API wrapper for matplotlib designed to streamline the process of creating, customizing, and managing plots in Python. By supporting method chaining and reusable functions, Viz makes complex plotting workflows easier to handle, while still offering complete control over matplotlib functionalities.


📦 Installation

To install the Viz package, use pip from PyPI (once it's published) or from the source.

Install via PyPI:

pip install mplviz

Install from Source:

git clone https://github.com/BBEK-Anand/mplviz.git
cd mplviz
pip install .

🚀 Quick Start

Here’s how you can use Viz to create a simple plot:

import matplotlib.pyplot as plt
from mplviz import Viz

# Create a figure and axis
fig, ax = plt.subplots()

# Initialize Viz with the axis
viz = Viz(ax, fig)

# Plot a line with customization
viz.plot([1, 2, 3], [4, 5, 6], label='Line') \
   .set_title("My Plot") \
   .xlabel("X Axis") \
   .ylabel("Y Axis") \
   .legend() \
   .grid(True) \
   .show()

🌟 Key Features

  • Method Chaining: Easily create readable and customizable plots with fluent syntax.
  • Support for Multiple Plot Types: Create line, scatter, bar charts, and more.
  • Grid and Axis Customization: Customize axis labels, grid visibility, and other settings.
  • Flexible Subplot Layout: Seamlessly create grid-based layouts with subplots.
  • Save and Export: Save plots to images or PDFs.
  • Reusability & Extensibility: Define reusable styles and settings for plots.

📊 Supported Plot Types

  • Line Plot: viz.plot()
  • Scatter Plot: viz.scatter()
  • Bar Chart: viz.bar()
  • Contour Plot: viz.contour()
  • Heatmaps/Images: viz.imshow()
  • Annotations: viz.annotate()
  • Axis Customization: viz.grid(), viz.set_xlim(), viz.set_ylim()
  • Subplots Layout: viz.add_subplot()
  • Multiple Y-Axes: viz.twinx()

🛠️ Method Overview

Basic Plotting

  • viz.plot(x, y, **kwargs) - Create a line plot.
  • viz.scatter(x, y, **kwargs) - Create a scatter plot.
  • viz.bar(x, y, **kwargs) - Create a bar chart.

Customization

  • viz.set_title(title, **kwargs) - Set the plot title.
  • viz.xlabel(text, **kwargs) - Set the x-axis label.
  • viz.ylabel(text, **kwargs) - Set the y-axis label.
  • viz.grid(flag=True, **kwargs) - Toggle grid lines on or off.
  • viz.legend(**kwargs) - Show the legend.

Layout and Saving

  • viz.show(clear=False) - Display the plot in the notebook.
  • viz.tight_layout(**kwargs) - Adjust subplot layout to prevent overlap.
  • viz.save(path, **kwargs) - Save the plot to a file.

🔄 Combine Multiple Plots

Combine multiple Viz objects into a single figure with subplots for side-by-side comparisons.

fig, axs = plt.subplots(2, 2, figsize=(10, 10))
viz1 = Viz(axs[0, 0])
viz2 = Viz(axs[0, 1])

viz1.plot([1, 2, 3], [4, 5, 6]).set_title("Plot 1")
viz2.scatter([1, 2, 3], [2, 3, 4]).set_title("Plot 2")

combined_viz = Viz.combine_viz([viz1, viz2])
combined_viz.show()

⚙️ Customization and Style

You can apply predefined matplotlib styles using plt.style for quick and consistent styling:

viz.style('seaborn-darkgrid')

🤝 Contributing

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature-name).
  3. Commit your changes (git commit -am 'Add feature').
  4. Push your branch (git push origin feature-name).
  5. Open a Pull Request.

📄 License

Distributed under the MIT License. See the LICENSE file for more information.


🙋‍♂️ Questions?

If you have any questions or issues, feel free to open an issue on the GitHub repository. You can also contribute by improving the documentation or adding new features!


📍 Future Enhancements

  • Adding interactive features with libraries like mplcursors or plotly.
  • Improving subplot layout and positioning for more complex figure structures.
  • Expanding export options (e.g., support for SVG, LaTeX-friendly outputs).
  • Automatic color-mapping for scatter plots or heatmaps.

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

mplviz-0.3.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

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

mplviz-0.3-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file mplviz-0.3.tar.gz.

File metadata

  • Download URL: mplviz-0.3.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for mplviz-0.3.tar.gz
Algorithm Hash digest
SHA256 d2b9b1ff800e748a6da389071d321bb33f04837e703c67899627442130213a7b
MD5 2a8dca7bf81080c8e6b743784cddbbee
BLAKE2b-256 54e0d8d5f5d7a2d42b0466f3ecb71752cc6ce7de5f837ac3d8c20372e46d03dc

See more details on using hashes here.

File details

Details for the file mplviz-0.3-py3-none-any.whl.

File metadata

  • Download URL: mplviz-0.3-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for mplviz-0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3cf2da339ecc3bf78d62d828cb174fec8f6370bbe22e1fa88990792c68a8d812
MD5 9a053a007a370dbefca61fc2415f127e
BLAKE2b-256 7a7b675fc4ef1ba24875064bd12225e9464740a8161978765269b80a5a790878

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