Interactive barplot with plotly

logo of a chart:Bar

This post explains how to build an interactive barplot using Python and the plotly library for data visualization.
It shows how to build a barplot using both the plotly express and the plotly graph objects APIs.

⏱ Quick start

Plotly has 2 distinct ways of creating graphs: plotly express and plotly graph objects, which we'll discuss below. The simplest way to build an interactive graph is to use the express API.

Once you've installed plotly using the pip install plotly command, you can create your first interactive graph.

import plotly.express as px

# Sample data
x_values = [1, 2, 3, 4, 5]
y_values = [2, 3, 4, 5, 6]

# Create a line chart using Plotly Express
fig = px.line(x=x_values, y=y_values, title="Simple Line Chart")

# Show the plot
fig.show()

Two distinct APIs

Important: In the gallery, we'll mainly be using the plolty.graph_objects API, as it's the one that allows the most customization. However, here we'll review the main differences between the 2 APIs available.

Plotly Express:

Plotly Express, a user-friendly high-level API, taps into Plotly's graphical capabilities to facilitate the swift creation of a diverse array of interactive visualizations. Its streamlined approach empowers users to generate a variety of chart types with minimal code. This abstraction shields users from intricate technical details, making it an ideal choice for those seeking an efficient visualization solution without compromising on sophistication.

In the following code, just 2 lines of code are needed to create an interactive bar chart, using the function px.bar().

import plotly.express as px

# Sample data
categories = ['A', 'B', 'C', 'D', 'E']
values = [15, 22, 18, 12, 28]

# Create a bar chart using Plotly Express
fig = px.bar(x=categories, y=values, title="Simple Bar Chart")

# Show the plot
fig.show()

Plotly Graph Objects:

In contrast, the Plotly Graph Objects API presents a finer level of control and customization within the Plotly framework. It encompasses essential objects like Figure, layout, and data, serving as the bedrock for constructing visualizations. The Figure, which can be represented as a dictionary or instances of plotly.graph_objects.Figure, undergoes JSON serialization before being handed off to plotly.js.

In the following code, compared to the Express API, we need to initiate a figure object (with a slightly more complex syntax) using the function go.Figure and then change the layout of this figure using the function fig.update_layout().

import plotly.graph_objects as go

# Sample data
categories = ['A', 'B', 'C', 'D', 'E']
values = [15, 22, 18, 12, 28]

# Create a bar chart using the Graph Object API
fig = go.Figure(data=[go.Bar(x=categories, y=values)])

# Update layout
fig.update_layout(title="Simple Bar Chart", xaxis_title="Categories", yaxis_title="Values")

# Show the plot
fig.show()

Importantly, the plotly.express module leverages plotly.graph_objects internally, enabling the creation of entire Figures in one go. This seamless integration underscores Plotly's versatility, bridging the gap between simplified creation and intricate customization for diverse visualization needs.

Customizing titles with Plotly

Customizing titles in Plotly graph objects is a straightforward way to enhance the visual appeal and clarity of your data visualizations. With Plotly, you have the flexibility to modify various aspects of the title, such as its text, font, color, alignment, and positioning. Here's a brief guide on how to customize titles using Plotly graph objects:

%%capture 

# Add and change title style
fig.update_layout(
    title='Custom Title',
    title_font=dict(size=24,
                    color='blue',
                    family='Arial'),
    title_x=0.5,  # Title positioned at the center horizontally
    title_y=0.9,  # Title positioned near the top vertically
)

Annotation

Annotation is a key part of a great visualization. It transforms a simple chart in a whole piece of story telling. Before you share your graph with anyone, make sure the key insight are highlighted with labels, shapes or color.

With plotly, we will mainly need to use the add_annotation() function.

%%capture

# Add annotation to a specific point
fig.add_annotation(
    x=2, y=11, # postion
    text="Annotated Point", # text
    showarrow=True,
    arrowhead=2,
    arrowsize=1,
    arrowwidth=2,
    arrowcolor="red"
)

⏱ Saving a plotly chart

Once you've created a plotly chart you probably want to save it as a standalone html file in order to share it or embed it in another webpage.

This is the code allowing to save a plotly chart. You can read the full process here for instance.

fig.write_html("the/path/to/chart-name.html")

⏱ Embeding a plotly chart

Once the chart has been saved, you can embed it in a html document using:

<iframe
  src="the/path/to/chart-name.html"
  width="800"
  height="600"
  title="chart name"
  style="border:none">
</iframe>

Plotly graph gallery

Here is a glimpse of the plotly charts showcased in the gallery:

Animation with python

Animation

Contact & Edit


👋 This document is a work by Yan Holtz. You can contribute on github, send me a feedback on twitter or subscribe to the newsletter to know when new examples are published! 🔥

This page is just a jupyter notebook, you can edit it here. Please help me making this website better 🙏!