Matplotlib Subplots: Best Practices and Examples
Last updated:data:image/s3,"s3://crabby-images/ce7d4/ce7d4200476b992e21cb3ca54145b54e127410ff" alt="Matplotlib Subplots: Best Practices and Examples"
Table of Contents
- 2 Plots side-by-side
- 2 Plots on top of the other
- 4 plots in a grid
- Pandas plots
- Set subplot title
- Padding between plots
- Align axes
Using Matplotlib v3 and pandas v1.0. See all code on this jupyter notebook
2 Plots side-by-side
Use fig, axes = plt.subplots(1,2)
import matplotlib.pyplot as plt
import numpy as np
# sample data
x = np.linspace(0.0,100,50)
y = np.random.uniform(low=0,high=10,size=50)
# create figure and axes
fig, (ax1,ax2) = plt.subplots(1,2) # 1 row, 2 columns
# just plot things on each individual axes
ax1.scatter(x,y,c='red',marker='+')
ax2.bar(x,y)
data:image/s3,"s3://crabby-images/89f06/89f06cd20f0871083e1ed628df150dfa91a1f253" alt="two-plots-side-by-side"
2 Plots on top of the other
Use fig, axes = plt.subplots(2,1)
:
import matplotlib.pyplot as plt
import numpy as np
# sample data
x = np.linspace(0.0,100,50)
y = np.random.uniform(low=0,high=10,size=50)
# create figure and axes
fig, (ax1,ax2) = plt.subplots(2,1)
# just plot things on each individual axes
ax1.scatter(x,y,c='red',marker='+')
ax2.bar(x,y)
data:image/s3,"s3://crabby-images/38506/38506f97633061a6ab57685afa22b904f07934e2" alt="two-plots-vertical"
4 plots in a grid
Use fig, ((ax1,ax2),(ax3,ax4)) = plt.subplots(2,2)
:
import matplotlib.pyplot as plt
import numpy as np
# sample data
x = np.linspace(0.0,100,50)
y = np.random.uniform(low=0,high=10,size=50)
# plt.subplots returns an array of arrays. We can
# directly assign those to variables directly
fig, ((ax1,ax2),(ax3,ax4)) = plt.subplots(2,2)
# just plot things on each individual axes
ax1.scatter(x,y,c='red',marker='+')
ax2.bar(x,y)
ax3.scatter(x,y,marker='x')
ax4.barh(x,y)
plt.show()
data:image/s3,"s3://crabby-images/a014a/a014a0fd185a303df0620917f24ff2ab93df2044" alt="four-plot-in-a-grid"
in 4 different ways, in 4 different
subplots.
Pandas plots
Call df.plot(...ax=<axis>)
, plot the chart in one of the suplot axes:
import matplotlib.pyplot as plt
import pandas as pd
# sample data
df = pd.DataFrame({
'string_col':['foo','bar','baz','quux','bum','bam','blah'],
'x':[10,20,30,40,20,10,30],
'y':[1,3,1,1,4,5,8]
})
# plt.subplots returns an array of arrays. We can
# directly assign those to variables directly
fig, ((ax1,ax2),(ax3,ax4)) = plt.subplots(2,2)
# bar plot for column 'x'
df.plot(y='x', kind='bar', ax=ax1)
# horizontal bar plot for column 'y'
df.plot(y='y', kind='bar', ax=ax2)
# both columns in a scatter plot
df.plot('x','y', kind='scatter', ax=ax3)
# to have two lines, plot twice in the same axis
df.plot(y='x', kind='line', ax=ax4)
df.plot(y='y', kind='line', ax=ax4)
data:image/s3,"s3://crabby-images/b8453/b8453da5db482a6c41e960e83643b1743f8f0cb7" alt="source-dataframe"
called
x
and y
data:image/s3,"s3://crabby-images/517d3/517d3b1e7a47caf725f249b49b3926e76d8eb66e" alt="four-plots-plotted-with-pandas"
bar plots for
x
and y
, scatter plot and two line plots together.
Set subplot title
Call <axis>.set_title(<title-text>)
on an individual axis object to set the title for that individual subplot only:
fig, ((ax1,ax2),(ax3,ax4)) = plt.subplots(2,2)
# sample data
x = np.linspace(0.0,100,50)
y = np.random.uniform(low=0,high=10,size=50)
# plot individual subplots
ax1.bar(x,y)
ax2.bar(x,y)
ax3.scatter(x,y)
ax4.plot(x)
ax4.set_title('This is Plot 4',size=14)
data:image/s3,"s3://crabby-images/9ac5f/9ac5f7734dc35da8895b25c30c0db1d971fd723c" alt="set-title-to-individual-plot"
Padding between plots
wspace
stands for width space,hspace
stands for height space
Use plt.subplots_adjust(wspace=<horizontal-padding>, hspace=<vertical-padding>)
. The default value is 0.2
import numpy as np
import matplotlib.pyplot as plt
# sample data
x = np.linspace(0.0,100,50)
y = np.random.uniform(low=0,high=10,size=50)
# plt.subplots returns an array of arrays. We can
# directly assign those to variables directly
fig, ((ax1,ax2),(ax3,ax4)) = plt.subplots(2,2)
# just plot things on each individual axes
ax1.scatter(x,y,c='red',marker='+')
ax2.bar(x,y)
ax3.scatter(x,y,marker='x')
ax4.barh(x,y)
# here, set the width and the height between the subplots
# the default value is 0.2 for each
plt.subplots_adjust(wspace=0.50, hspace=1.0)
data:image/s3,"s3://crabby-images/9ab9a/9ab9acb298dc252a9af25ec0a445f5f544b050cb" alt="subplots-with-custom-padding"
wspace
to 0.50 and hspace
to 1.0 to increase the width and the height, respectively.
Align axes
To make axes for subplots match each other, call <axis>.set_xlim(<start>,<end>)
to configure x-axis and <axis>.set_ylim(<start>,<end>)
to configure y-axis:
import numpy as np
import matplotlib.pyplot as plt
# plt.subplots returns an array of arrays. We can
# directly assign those to variables directly
fig, ((ax1,ax2)) = plt.subplots(1,2)
# sample data in different magnitudes
x = np.linspace(0.0,100,50)
y1 = np.random.normal(loc=10, scale=2, size=10)
y2 = np.random.normal(loc=20, scale=2, size=10)
# plot in each subplot
ax1.plot(y1)
ax2.plot(y2)
ax1.set_ylim(0,25)
ax2.set_ylim(0,25)
data:image/s3,"s3://crabby-images/97373/97373ac8b9ad7b933c2da0c6c9884634f0ac2ba7" alt="original-subplots"
defined by the data in the
plot, so each will
be different, making it
hard to read
data:image/s3,"s3://crabby-images/cc27f/cc27f07eb9fed9ea0bca0820fa7bb5c0ad14b52b" alt="subplots-with-configured-y-axes"
subplots have the same limits
so that they are directly
comparable