Skip to content

Plotly

Plotly express

Usage

Facet and Trellis Plots

Facet plots, also known as trellis plots or small multiples, are figures made up of multiple subplots which have the same set of axes, where each subplot shows a subset of the data.

Example:

import plotly.express as px
df = px.data.gapminder()
fig = px.scatter(df, x='gdpPercap', y='lifeExp', color='continent', size='pop',
                facet_col='year', facet_col_wrap=4)
fig.show()

!(../../../img/facet.png)

Convert Matplotlib figure to Plotly

For better aesthetics and interactivity, you can convert Matplotlib figures, that often are returned by existing libraries, to Plotly with:

import plotly.tools as tls

x = np.random.random(100)  # toy data
y = np.random.random(100)  # toy data

## matplotlib fig
fig, axes = plt.subplots(2,1, figsize = (10,6))
axes.plot(x, label = 'x')
axes.scatter(x,y)

## convert and plot in plotly
tls.mpl_to_plotly(fig)

Dash

(https://dash.plotly.com/) is a productive Python framework for building web analytic applications.

Configuration

Reverse proxy

There might be issues with the request URLs if the app is served under a non-root directory of a domain (e.g., domain.tld/dashboard/). This is because Dash uses some absolute paths by default.

Use the following configuration to avoid this issues:

app = dash.Dash(__name__)
app.config.update(
    {
        "routes_pathname_prefix": "", # default is /
        "requests_pathname_prefix": "/{path}/",
    }
)

Then if you use NGINX:

location /{path}/ {
        proxy_pass http://127.0.0.1:{binded_port}/;
}

Interactive visualizations

The dash_core_components library includes a component called Graph.

Graph renders interactive data visualizations using the open source plotly.js JavaScript graphing library. plotly.js supports over 35 chart types and renders charts in both vector-quality SVG and high-performance WebGL.

The figure argument in the dash_core_components.Graph component is the same figure argument that is used by plotly.py.

Dash components are described declaratively by a set of attributes. All of these attributes can be updated by callback functions, but only a subset of these attributes are updated through user interaction, such as when you click on an option in a dcc.Dropdown component and the value property of tha component changes.

The dcc.Graph component has four attributes that can change through user-interaction: hoverData, clickData, selectedData, relayoutData.