Skip to main content

Create beautiful JavaScript charts with one line of Python

Project description

Chartkick.py

Create beautiful JavaScript charts with one line of Python. No more fighting with charting libraries!

See it in action

Build Status

Quick Start

Run:

pip install chartkick

Then follow the instructions for your web framework:

This sets up Chartkick with Chart.js. For other charting libraries, see these instructions.

Django

Add to INSTALLED_APPS in settings.py

INSTALLED_APPS = [
    'chartkick.django',
    # ...
]

Load the JavaScript

{% load static %}

<script src="{% static 'chartkick/Chart.bundle.js' %}"></script>
<script src="{% static 'chartkick/chartkick.js' %}"></script>

Create a chart in a view

from chartkick.django import PieChart

def index(request):
    chart = PieChart({'Blueberry': 44, 'Strawberry': 23})
    return render(request, 'home/index.html', {'chart': chart})

And add it to the template

{{ chart }}

Flask

Register the blueprint

from chartkick.flask import chartkick_blueprint

app.register_blueprint(chartkick_blueprint)

Load the JavaScript

<script src="{{ url_for('chartkick.static', filename='Chart.bundle.js') }}"></script>
<script src="{{ url_for('chartkick.static', filename='chartkick.js') }}"></script>

Create a chart in a route

from chartkick.flask import PieChart

def index():
    chart = PieChart({'Blueberry': 44, 'Strawberry': 23})
    return render_template('home/index.html', chart=chart)

And add it to the template

{{ chart }}

Charts

Line chart

LineChart({'2025-01-01': 11, '2025-01-02': 6})

Pie chart

PieChart({'Blueberry': 44, 'Strawberry': 23})

Column chart

ColumnChart({'Sun': 32, 'Mon': 46, 'Tue': 28})

Bar chart

BarChart({'Work': 32, 'Play': 1492})

Area chart

AreaChart({'2025-01-01': 11, '2025-01-02': 6})

Scatter chart

ScatterChart([[174.0, 80.0], [176.5, 82.3]], xtitle='Size', ytitle='Population')

Geo chart - Google Charts

GeoChart({'United States': 44, 'Germany': 23, 'Brazil': 22})

Timeline - Google Charts

Timeline([['Washington', '1789-04-29', '1797-03-03'], ['Adams', '1797-03-03', '1801-03-03']])

Multiple series

data = [
    {'name': 'Workout', 'data': {'2025-01-01': 3, '2025-01-02': 4}},
    {'name': 'Call parents', 'data': {'2025-01-01': 5, '2025-01-02': 3}}
]
LineChart(data)

Data

Data can be a dictionary, list, or URL.

Dictionary

LineChart({'2025-01-01': 2, '2025-01-02': 3})

List

LineChart([['2025-01-01', 2], ['2025-01-02', 3]])

URL

Make your pages load super fast and stop worrying about timeouts. Give each chart its own endpoint.

LineChart('/charts/tasks')

Options

Width and height

LineChart(data, width='800px', height='500px')

Min and max values

LineChart(data, min=1000, max=5000)

min defaults to 0 for charts with non-negative values. Use None to let the charting library decide.

Min and max for x-axis - Chart.js

LineChart(data, xmin='2025-01-01', xmax='2025-02-01')

Colors

LineChart(data, colors=['#b00', '#666'])

Stacked columns or bars

ColumnChart(data, stacked=True)

Discrete axis

LineChart(data, discrete=True)

Label (for single series)

LineChart(data, label='Value')

Axis titles

LineChart(data, xtitle='Time', ytitle='Population')

Straight lines between points instead of a curve

LineChart(data, curve=False)

Hide points

LineChart(data, points=False)

Show or hide legend

LineChart(data, legend=False)

Specify legend position

LineChart(data, legend='bottom')

Donut chart

PieChart(data, donut=True)

Prefix, useful for currency - Chart.js, Highcharts

LineChart(data, prefix='$')

Suffix, useful for percentages - Chart.js, Highcharts

LineChart(data, suffix='%')

Set a thousands separator - Chart.js, Highcharts

LineChart(data, thousands=',')

Set a decimal separator - Chart.js, Highcharts

LineChart(data, decimal=',')

Set significant digits - Chart.js, Highcharts

LineChart(data, precision=3)

Set rounding - Chart.js, Highcharts

LineChart(data, round=2)

Show insignificant zeros, useful for currency - Chart.js, Highcharts

LineChart(data, round=2, zeros=True)

Friendly byte sizes - Chart.js

LineChart(data, bytes=True)

Specify the message when data is loading

LineChart(data, loading='Loading...')

Specify the message when data is empty

LineChart(data, empty='No data')

Refresh data from a remote source every n seconds

LineChart(url, refresh=60)

You can pass options directly to the charting library with:

LineChart(data, library={'backgroundColor': '#eee'})

See the documentation for Chart.js, Google Charts, and Highcharts for more info.

To customize datasets in Chart.js, use:

LineChart(data, dataset={'borderWidth': 10})

You can pass this option to individual series as well.

Multiple Series

You can pass a few options with a series:

  • name
  • data
  • color
  • dataset - Chart.js only
  • points - Chart.js only
  • curve - Chart.js only

Code

If you want to use the charting library directly, get the code with:

LineChart(data, code=True)

The code will be logged to the JavaScript console. JavaScript functions cannot be logged, so it may not be identical.

Download Charts

Chart.js only

Give users the ability to download charts. It all happens in the browser - no server-side code needed.

LineChart(data, download=True)

Safari will open the image in a new window instead of downloading.

Set the filename

LineChart(data, download={'filename': 'boom'})

Set the background color

LineChart(data, download={'background': '#ffffff'})

Set title

LineChart(data, title='Awesome chart')

Additional Charting Libraries

Google Charts

Load the JavaScript

Django

{% load static %}

<script src="https://www.gstatic.com/charts/loader.js"></script>
<script src="{% static 'chartkick/chartkick.js' %}"></script>

Flask

<script src="https://www.gstatic.com/charts/loader.js"></script>
<script src="{{ url_for('chartkick.static', filename='chartkick.js') }}"></script>

Highcharts

Download highcharts.js and load the JavaScript

Django

{% load static %}

<script src="{% static 'highcharts.js' %}"></script>
<script src="{% static 'chartkick/chartkick.js' %}"></script>

Flask

<script src="{{ url_for('static', filename='highcharts.js') }}"></script>
<script src="{{ url_for('chartkick.static', filename='chartkick.js') }}"></script>

Multiple Libraries

If more than one charting library is loaded, choose between them with:

LineChart(data, adapter='google')  # or highcharts or chartjs

Credits

A big thanks to Mher Movsisyan for creating the initial version.

History

View the changelog

Contributing

Everyone is encouraged to help improve this project. Here are a few ways you can help:

To get started with development:

git clone https://github.com/ankane/chartkick.py.git
cd chartkick.py
pip install -r requirements.txt
pytest

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

chartkick-1.1.0.tar.gz (192.5 kB view details)

Uploaded Source

Built Distribution

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

chartkick-1.1.0-py3-none-any.whl (194.9 kB view details)

Uploaded Python 3

File details

Details for the file chartkick-1.1.0.tar.gz.

File metadata

  • Download URL: chartkick-1.1.0.tar.gz
  • Upload date:
  • Size: 192.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.7

File hashes

Hashes for chartkick-1.1.0.tar.gz
Algorithm Hash digest
SHA256 e815a11806ba541e31d32ecd583b76e54a7e929aaaab76972ae44f0d841c0df3
MD5 6b817590fc734a7a6828bc127f17c79e
BLAKE2b-256 44dc20450c12a79ce1db6478d692fff7a598973129ce5668d808a7e19a46aa99

See more details on using hashes here.

File details

Details for the file chartkick-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: chartkick-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 194.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.7

File hashes

Hashes for chartkick-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 13879a8395c8a7544d72a649d0da10c14f8bd75eb4b841ba6415fae69c195471
MD5 1f9b014f3564ebd5000b287fd4d2deb2
BLAKE2b-256 f24efc6560445c0b7bdcbf61b2c55a4ae1bd6cba32e14976f326f6ee336731ac

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