Jupyter, Django & Altair
Quick and dirty business analytics
Djangocon Eu 2019
Chris Adams
Hello! My name is Chris Adams
data:image/s3,"s3://crabby-images/0c293/0c29350f70fc6b9f8d114816a4a4f53bd064b2e1" alt=""
Not this GuyΒ
This GuyΒ
Chris Adams
@acdha
Chris Adams
@mrchrisadams
data:image/s3,"s3://crabby-images/a77a8/a77a8a171207e9eacf42fbde96ba2ad3033bb6c3" alt=""
data:image/s3,"s3://crabby-images/25b00/25b0055052353a1fbd18a4c5176c2f2227de42bc" alt=""
Successful, prolific, well known django developer
Environmentally focussed web generalist
Jupyter
Altair
Django
Notebooks
Theory
Applying it
Notebooks
data:image/s3,"s3://crabby-images/c7569/c756978ba69e95a21f14b89daf37ed123695455c" alt=""
jupyter
data:image/s3,"s3://crabby-images/a0be2/a0be22665c4484adb58c6ba9c552c3070c6e23aa" alt=""
Narratives
collaborative
shareable
publishable
reproducible
Β
That's nice.
Who's using them though?
Currency trading with Economist and the Big Mac Index
... and now the source
data:image/s3,"s3://crabby-images/1047a/1047a1551d26d42b505328a949b5560ff3cc9b70" alt=""
Education
data:image/s3,"s3://crabby-images/1b9f4/1b9f4781c3f2e36725d8d616eeb23fa32cefe291" alt=""
Operations
data:image/s3,"s3://crabby-images/92212/92212fa899b63837a5032b146b9475e45543c456" alt=""
Business Analytics
How is this possible?
Ju
Py
teR
data:image/s3,"s3://crabby-images/ad782/ad782a0cd0feca542ddb565303ab4f940c6d3a3c" alt=""
Decoupled Kernels
data:image/s3,"s3://crabby-images/10e6b/10e6b2bf3f161777860c1618255314c7c19f53ca" alt=""
Browsers vs terminals
data:image/s3,"s3://crabby-images/10e6b/10e6b2bf3f161777860c1618255314c7c19f53ca" alt=""
class CoolRedCar(models.Model):
# please don't do this in real life
model = models.CharField(max_length=254)
top_speed = models.FloatField()
def __str__(self):
# should be __repr__()
# if you just want the emoji
return "π"
./manage.py shell
In [1]: cart = ShoppingCart.objects.get(
user="chris"
)
Out[1]: π
In [2]: [item for item in cart.items()]
Out[2]: [π, π, π§, πΎ, π₯]
How might we represent objects if we had a whole browser, instead of a terminal?
Finding a better representation of data
geojson
data:image/s3,"s3://crabby-images/3adc0/3adc0ae2b75003a8e44c4f9cd0a8479b42baf12e" alt=""
It's easy to get viz wrong
pip install viz-knowledge
Theory
Tamara Munzner
Author of Visualization Analysis and Design
data:image/s3,"s3://crabby-images/2dfe8/2dfe84c0865307fad0b6dd2f51f538560e06354d" alt=""
data:image/s3,"s3://crabby-images/d6f29/d6f29021da8c8ca5b4ac9a4f3c0febe001477615" alt=""
@tamaramunzner
"Oh my god, this woman has figured it *all* out"
Primitives for designing viz
Datatypes
(a bit like our data structures)
Attributes
(we call them that too)
Marks
(stuff on a screen or page)
Channels
(info we encode in the marks)
Examples
(so we can get comfortable with these ideas)
mark:
bar
Β
channel:
x position
length
mark:
point
Β
channel:
x-position
y-position
mark:
point
Β
channel:
x position
y position
colour
mark:
point
Β
channel:
x position
y position
colour
size
Which channels work best with which marks?
data:image/s3,"s3://crabby-images/9be4e/9be4e603af694f189706667b1aced6dafd1783ef" alt=""
How do we use this?
data:image/s3,"s3://crabby-images/7d853/7d8537b07add0e5f89a6f2e30d4fc0f870f9588b" alt=""
data:image/s3,"s3://crabby-images/7431a/7431abf7de3de62566348a6ce6947d755ed43dc4" alt=""
data:image/s3,"s3://crabby-images/ff27b/ff27b68f53b3b62718ef2dfe5487940f7e576820" alt=""
How do we use this β¦ in Python?
import handylibrary as lib
# fetch our data
url = "https://domain.com/data/seattle-weather.csv"
# make our chart using our "marks and channels" grammar
lib.Chart(url).mark_bar().encode(
alt.Y(
'precipitation',
type="quantitative"
),
alt.X(
'date',
type="ordinal",
timeUnit="month"
)
)
data:image/s3,"s3://crabby-images/73812/7381220dbc142d5bb36cdd39110229266f718083" alt=""
What it's doing under the hood
Altair
Vega-lite
Vega
D3
SVG / Canvas
π
π
π
π¬
π°
We get to stay up here
(But can get help here if we want it)
Thanks Jake (and friends!)
data:image/s3,"s3://crabby-images/f88f2/f88f263dd57eff8b5ca8f789a73585964c357190" alt=""
Applying it
Remember this?
data:image/s3,"s3://crabby-images/10e6b/10e6b2bf3f161777860c1618255314c7c19f53ca" alt=""
Our setup with django
ORM
Altair
Browser
π
fetch data our django app
render vega-lite in browser, with template tag or similar
import altair as alt
from django.http import JsonResponse
from django.shortcuts import render
from .models import MyModel
def my_cool_chart_view(req):
query = MyModel.objects.all().values()
data = alt.Data(values=list(query))
chart_obj = alt.Chart(data).mark_bar().encode(
# encode your data using the channels
# and marks grammar we covered before
# you want here
)
return JsonResponse(chart_obj)
def index_page(req):
render(req, "index_page.html")
views.py
from django.urls import include, path
from . import views
urlpatterns = [
path('cool_chart/',
views.my_cool_chart_view,
name='my-cool-chart'
),
path('index/',
views.viz_index_page,
name='index-page'
),
]
urls.py
<!DOCTYPE html>
<html>
<head>
<!-- Load Vega, Vega-Lite & Vega Embed -->
<script src="{% static 'src/assets/vega.min.js' %}"></script>
<script src="{% static 'src/assets/vega-lite.min.js' %}"></script>
<script src="{% static 'src/assets/vega-embed.min.js' %}"></script>
</head>
<body>
<div id="viz">
<!-- viz will replace content here -->
</div>
<script type="text/javascript">
var spec = "{% url 'my-cool-chart' %}";
// transform the vega spec from altair as JSON,
// and render our cool viz on the page
vegaEmbed('#viz', spec)
</script>
</body>
</html>
index_page.html
Quick and dirty example
Drawdown
data:image/s3,"s3://crabby-images/21cd4/21cd400b8f5f094f016a219f33f660c21bd361e7" alt=""
please smile on me⦠demo gods
data:image/s3,"s3://crabby-images/af6f8/af6f846c8e55ff14d19da4fdde9ae6bce6f1cfa1" alt=""
data:image/s3,"s3://crabby-images/bd64b/bd64b9214c4af8a7bc5b1db153350239136ad1d1" alt=""
2/3 of public sector's CO2 emissions is in its supply chain. It's huge. Help us change this!
Notebooks
Theory
Applying it
Jupyter
Altair
Django
Thanks!
@mrchrisadams
chris@productscience.net
Β
http://bit.ly/django-con-eu-2019-viz
http://github.com/mrchrisadams/djangocon-eu-2019
Β
Come to the Green your Django Project workshop tomorrow
Jupyter, Django and Altair - Quick and Dirty Business Analytics
By Chris Adams
Jupyter, Django and Altair - Quick and Dirty Business Analytics
My talk for Djangocon EU 2019 in Copenhagen
- 1,341