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
- Fork the repository.
- Create a new branch (
git checkout -b feature-name). - Commit your changes (
git commit -am 'Add feature'). - Push your branch (
git push origin feature-name). - 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
mplcursorsorplotly. - 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
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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f73d3280d95cc018c506fef87eb95acdca8381d0ce9492fac785f4b28f23d94a
|
|
| MD5 |
1859c298e6022e9be01806eae7b05640
|
|
| BLAKE2b-256 |
2c3a9cb495b6101204b9603a7d4c7cd40eab58e43de5681c2f491093628511d6
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
330af39595c1ae8f3e4a52c5457ba9cb9c0fc579385bb0086fce8b5ae4ab8977
|
|
| MD5 |
55825efb4b872da80eaf46cce802cc89
|
|
| BLAKE2b-256 |
24735b4270771f65814bdc53581303f661fa628bb62c7715dcff23a8d840f837
|