Skip to main content

A fluent wrapper around matplotlib for easy, expressive visualizations

Project description

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.2.0.tar.gz (11.7 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.2.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for mplviz-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f73d3280d95cc018c506fef87eb95acdca8381d0ce9492fac785f4b28f23d94a
MD5 1859c298e6022e9be01806eae7b05640
BLAKE2b-256 2c3a9cb495b6101204b9603a7d4c7cd40eab58e43de5681c2f491093628511d6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mplviz-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.2 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 330af39595c1ae8f3e4a52c5457ba9cb9c0fc579385bb0086fce8b5ae4ab8977
MD5 55825efb4b872da80eaf46cce802cc89
BLAKE2b-256 24735b4270771f65814bdc53581303f661fa628bb62c7715dcff23a8d840f837

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