Skip to main content

Python library to make plotting simpler for data scientists

Project description

status release python CI

Chartify is a Python library that makes it easy for data scientists to create charts.

Why use Chartify?

  • Consistent input data format: Spend less time transforming data to get your charts to work. All plotting functions use a consistent tidy input data format.

  • Smart default styles: Create pretty charts with very little customization required.

  • Simple API: We’ve attempted to make the API as intuitive and easy to learn as possible.

  • Flexibility: Chartify is built on top of Bokeh, so if you do need more control you can always fall back on Bokeh’s API.

Examples

https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify1.png https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify2.png https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify3.png https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify4.png https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify5.png https://raw.githubusercontent.com/spotify/chartify/master/docs/_static/chartify6.png

See this notebook for more examples!.

Installation

  1. Chartify can be installed via pip:

pip3 install chartify

  1. Install chromedriver requirement (Optional. Needed for PNG output):
    • Install google chrome.

    • Download the appropriate version of chromedriver for your OS here.

    • Copy the executable file to a directory within your PATH.
      • View directorys in your PATH variable: echo $PATH

      • Copy chromedriver to the appropriate directory, e.g.: cp chromedriver /usr/local/bin

Getting started

This tutorial notebook is the best place to get started with a guided tour of the core concepts of Chartify.

From there, check out the example notebook for a list of all the available plots.

Docs

Documentation available on chartify.readthedocs.io

Getting support

Join #chartify on spotify-foss.slack.com (Get an invite)

Use the chartify tag on StackOverflow.

Resources

Code of Conduct

This project adheres to the Open Code of Conduct. By participating, you are expected to honor this code.

Contributing

See the contributing docs.

History

3.1.0 (2023-03-22)

  • Added Boxplot Chart including example in examples notebook

3.0.5 (2022-12-13)

  • Fixed a few errors in example and tutorial notebooks

  • Fixed a typo in requirements.txt

3.0.4 (2022-10-18)

  • Updated package requirements

  • Got rid of future deprecation warnings

  • Bugfix related to legend for graphs with multiple groups and colors

3.0.2 (2020-10-21)

  • Support pyyaml 5.2+

3.0.1 (2020-06-02)

  • Reduce dependencies by switching from Jupyter to IPython.

3.0.0 (2020-05-29)

  • Updated Python to 3.6+ and Pandas to 1.0+ (Thanks @tomasaschan!)

  • Updated Bokeh to 2.0+

  • Removed colour dependency to fix setup errors.

2.7.0 (2019-11-27)

Bugfixes:

  • Updated default yaml loader to move off of deprecated method (Thanks @vh920!)

  • Updated legend handling to adjust for deprecated methods in recent versions of Bokeh (Thanks for reporting @jpkoc)

  • Updated license in setup.py (Thanks for reporting @jsignell)

  • Bump base Pillow dependency to avoid insecure version.

  • Update MANIFEST to include missing files (Thanks @toddrme2178!)

2.6.1 (2019-08-15)

Bugfixes:

  • Moved package requirements and fixed bug that occured with latest version of Bokeh (Thanks @emschuch & @mollymzhu!)

  • Fixed bug in README while generating docs (Thanks @Bharat123rox!)

2.6.0 (2019-03-08)

Improvements:

  • Allows users to plot colors on bar charts that aren’t contained in the categorical axis.

Bugfixes:

  • Fixed bug that caused float types to break when plotted with categorical text plots (Thanks for finding @danela!)

  • Fixed broken readme links.

2.5.0 (2019-02-17)

Improvements:

  • Added Radar Chart

2.4.0 (2019-02-16)

Improvements:

  • Added second Y axis plotting.

  • Removed Bokeh loading notification on import (Thanks @canavandl!)

  • Added support for custom Bokeh resource loading (Thanks @canavandl!)

  • Added example for Chart.save() method (Thanks @david30907d!)

Bugfixes:

  • Updated documentation for saving and showing svgs.

  • Fixed bug that broke plots with no difference between min and max points. (Thanks for finding @fabioconcina!)

2.3.5 (2018-11-21)

Improvements:

  • Updated docstrings (Thanks @gregorybchris @ItsPugle!)

  • Added SVG output options to Chart.show() and Chart.save() (Thanks for the suggestion @jdmendoza!)

Bugfixes:

  • Fixed bug that caused source label to overlap with xaxis labels.

  • Fixed bug that prevented x axis orientation changes with datetime axes (Thanks for finding @simonwongwong!)

  • Fixed bug that caused subtitle to disappear with outside_top legend location (Thanks for finding @simonwongwong!)

  • Line segment callout properties will work correctly. (Thanks @gregorybchris!)

2.3.4 (2018-11-13)

  • Updated Bokeh version requirements to support 1.0

2.3.3 (2018-10-24)

  • Removed upper bound of Pillow dependency.

2.3.2 (2018-10-18)

  • Stacked bar and area order now matches default vertical legend order.

  • Added method for shifting color palettes.

  • Added scatter plots with a single categorical axis.

  • Fixed bug with text_stacked that occurred with multiple categorical levels.

2.3.1 (2018-09-27)

  • Fix scatter plot bug that can occur due to nested data types.

2.3.0 (2018-09-26)

  • Added hexbin plot type.

  • More control over grouped axis label orientation.

  • Added alpha control to scatter, line, and parallel plots.

  • Added control over marker style to scatter plot.

  • Added ability to create custom color palettes.

  • Changed default accent color.

  • Visual tweaks to lollipop plot.

  • Bar plots with a few number of series will have better widths.

2.2.0 (2018-09-17)

  • First release on PyPI.

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

chartify-3.1.0.tar.gz (4.8 MB view details)

Uploaded Source

Built Distribution

chartify-3.1.0-py2.py3-none-any.whl (64.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file chartify-3.1.0.tar.gz.

File metadata

  • Download URL: chartify-3.1.0.tar.gz
  • Upload date:
  • Size: 4.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for chartify-3.1.0.tar.gz
Algorithm Hash digest
SHA256 21c0a9b4c66bc663a2a71a0058acabecf4ebc9f18db4d5d27ef63983e51036cc
MD5 2e55fc4b6f61e760a035b51e7d0a0912
BLAKE2b-256 a0db5aa9939967d7748819972fd7a8f0fe02512168f02967cb8ded29dad503cc

See more details on using hashes here.

File details

Details for the file chartify-3.1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: chartify-3.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 64.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for chartify-3.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 565fd0ddc9fdda170576268c70a9d4750a5a18a527c3dc1d977c8e8d12c036a0
MD5 107fa9c1b361a74478459ddc79ce07fb
BLAKE2b-256 850b604d43a15d45b7c23874e8f947717e22360b6ce2f8325f2bb012cbf6c7e6

See more details on using hashes here.

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