Skip to main content

BSIC Plotting Library

Project description


Logo

mpl-bsic

Create matplotlib plots in BSIC Style!

Explore the docs »

Report Bug - Request Feature

Contributors Issues License

About the Project

Plot Example

This package allows you to style matplotlib plots using BSIC Style (fonts, colors, logos, etc.) to later use them in BSIC articles. It also provides utility function to plot trades, handle the formatting of the axis, check the size of the figures, and more!

Read the sections below for an overview of how to install and use the package. For further information, be sure to read the docs!

Table Of Contents

Installation

The package supports all python versions starting from 3.9.0

To install, run

pip install mpl-bsic

Then you can import the functions from the module, for example

from mpl_bsic import apply_bsic_style

Docs and TLDR

Read the docs on this link. All the functions are explained extensively and you can find example code/plots.

WARNING: Be sure to read the docs for apply_bsic_style, and in particular how to make sure the style gets applied. You always have to make sure you call plt.show() (if in a script) even if you only plan to export the plot, since otherwise matplotlib won't run the animations which are required to apply the style to the title. And also read carefully the part about the figsize to use, especially when exporting to use in a Word file.

A brief overview of the functions of the module:

  • apply_bsic_style: applies the BSIC styles to a plot (font families, font sizes).
  • apply_bsic_logo: applies the BSIC logo to the plot. You can specify the size, location and logo type.
  • plot_trade: plots performance of the trade and path of underlying in BSIC style, with the possibility to specify additional parameters regarding formatting and visualization
  • check_figsize: checks the figsize of your plot, to make sure it will be rendered correctly in MS Word. Returns the correct figure width and height to use
  • format_timeseries_axis: formats the x axis of a timeseries plot. You can specify the time unit (yearly, monthly, daily), the frequency (e.g. a tick every 3M), and the format (e.g. MM/YYYY or MMM YYYY)
  • preprocess_dataframe: preprocesses a dataframe, by setting the index to the date (and converting to datetime) and transforming all the columns to lowercase for easier use in the project

If the matplotlib fonts do not work

Starting from version 1.2, apply_bsic_style will temporarily install the fonts (Garamond and Gill Sans MT) using FontManager in matplotlib, so that plots still get styled correctly.

For perfomance, however, this could not be the wisest choice, and you can refer to the documentation on how to properly install the fonts on your system and make them recognizable my matplotlib.

Contributing

If you have any ideas, features you would like to have implemented, or you find out any bugs within the function, be sure to open an issue and I will work on it as soon as possible. Or you can also fork the repo yourself and make a PR to the project!

Roadmap

  1. plot tables (instead of having to style them using Excel)

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

mpl_bsic-1.4.0a1.tar.gz (5.1 MB view details)

Uploaded Source

Built Distribution

mpl_bsic-1.4.0a1-py3-none-any.whl (5.1 MB view details)

Uploaded Python 3

File details

Details for the file mpl_bsic-1.4.0a1.tar.gz.

File metadata

  • Download URL: mpl_bsic-1.4.0a1.tar.gz
  • Upload date:
  • Size: 5.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.0 Windows/10

File hashes

Hashes for mpl_bsic-1.4.0a1.tar.gz
Algorithm Hash digest
SHA256 cd2c40b53ec55ec6e3d883d5085eea022d94a45f6f782b3c08bdbf86e96ca081
MD5 891a89c9c43f1f15af703b6c3aea9568
BLAKE2b-256 4f5ff0ea858c6eca42ab5f1a150faf82c5e3def0a6c2828d61bd88b94cd46e0a

See more details on using hashes here.

Provenance

File details

Details for the file mpl_bsic-1.4.0a1-py3-none-any.whl.

File metadata

  • Download URL: mpl_bsic-1.4.0a1-py3-none-any.whl
  • Upload date:
  • Size: 5.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.0 Windows/10

File hashes

Hashes for mpl_bsic-1.4.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 9acdd56ffe76efd534181b35375cf8674eda89be17d267091f4ea77741f6a518
MD5 6da22ec480a63d572dcda8ecd306e1e2
BLAKE2b-256 4988c2492cdbddd797748b7ddfd4354ec506f336eca901181b7fd184b4a66d40

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page