Day 9: Data Visualization with Matplotlib (Part 2)

Python for Data Science

Muhammad Dawood
5 min readJul 24, 2023

Welcome to Day 9 of our Python for data science challenge! Today, we will continue our exploration of Matplotlib and dive into more advanced data visualization techniques. Creating bar plots and histograms, working with subplots and multiple axes, and adding legends and annotations will further enhance your ability to create captivating visualizations in Python. Let’s continue our journey into the world of Matplotlib and elevate your data visualization skills!

Combining Multiple Plots for Comprehensive Data Analysis:

Matplotlib allows you to create and arrange multiple plots on a single figure, enabling you to gain a concise overview of various data insights. You can use the plt.subplots() function to create a grid of subplots and place different visualizations in each subplot.

Here’s an example of creating and arranging subplots on a single figure:

import matplotlib.pyplot as plt

# Sample data
x = [1, 2, 3, 4, 5]
y1 = [10, 25, 18, 30, 15]
y2 = [5, 20, 12, 28, 10]

# Creating a 2x1 grid of subplots
fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(8, 6))

# Plot data on the first subplot
ax1.plot(x, y1, marker='o', color='b')
ax1.set_xlabel('X-axis label')
ax1.set_ylabel('Y-axis label')
ax1.set_title('Line Plot')

# Plot data on the second subplot
ax2.scatter(x, y2, marker='s', color='r')
ax2.set_xlabel('X-axis label')
ax2.set_ylabel('Y-axis label')
ax2.set_title('Scatter Plot')

# Adjust the space between subplots to avoid overlapping titles and labels
plt.tight_layout()

plt.show()

Output:

Adding Legends and Annotations:

Legends help differentiate multiple datasets in a plot, making it easier to interpret the information. To add legends, you can use the label parameter when plotting data and then call the plt.legend() function.

Here’s an example of adding legends to a plot:

import matplotlib.pyplot as plt

# Sample data
x = [1, 2, 3, 4, 5]
y1 = [10, 25, 18, 30, 15]
y2 = [5, 20, 12, 28, 10]

plt.plot(x, y1, marker='o', linestyle='--', color='b', label='Data 1')
plt.scatter(x, y2, marker='s', color='r', label='Data 2')

plt.xlabel('X-axis label')
plt.ylabel('Y-axis label')
plt.title('Line Plot and Scatter Plot')
plt.legend()

plt.show()

Output:

Annotations are useful for highlighting specific points or observations in a plot. You can use the plt.annotate() function to add annotations.

Here’s an example of adding annotations to a plot:

import matplotlib.pyplot as plt

# Sample data
x = [1, 2, 3, 4, 5]
y = [10, 25, 18, 30, 15]

plt.plot(x, y, marker='o', linestyle='--', color='b', label='Data')

# Adding an annotation
plt.annotate('Important Point', xy=(3, 18), xytext=(3.5, 20),
arrowprops=dict(facecolor='black', arrowstyle='->'))

plt.xlabel('X-axis label')
plt.ylabel('Y-axis label')
plt.title('Line Plot with Annotation')
plt.legend()

plt.show()

Output:

Visualizing Data Trends:

Visualizing data trends is crucial for understanding patterns and insights. Matplotlib provides various plot types to display cumulative data trends, such as stacked bar plots and area charts.

Here’s an example of creating a stacked bar plot:

import matplotlib.pyplot as plt

# Sample data
categories = ['Category 1', 'Category 2', 'Category 3']
data1 = [20, 30, 15]
data2 = [10, 25, 30]

plt.bar(categories, data1, label='Data 1')
plt.bar(categories, data2, bottom=data1, label='Data 2')

plt.xlabel('Categories')
plt.ylabel('Values')
plt.title('Stacked Bar Plot')
plt.legend()

plt.show()

Output:

For visualizing time series data and revealing seasonal patterns, you can use line plots or area charts with appropriate x-axis values representing time.

Practical Application:

Let’s dive into some practical examples to explore the advanced data visualization capabilities of Matplotlib. These examples will help us understand how to compare categorical data, visualize data distributions, and uncover trends and patterns in time series data.

  1. Comparing Categorical Data: Imagine we have survey data from a group of participants who were asked to rate three different products — A, B, and C — on a scale of 1 to 5. We want to compare the average ratings for each product using a bar chart.
  2. Visualizing Data Distributions: Suppose we have a dataset of exam scores from a class of students. We can create a histogram to visualize the distribution of scores and understand how many students fall within each score range.
  3. Uncovering Trends in Time Series Data: Consider a dataset containing daily temperature recordings over several years. We can use a line plot to visualize how the temperature changes over time and identify any seasonal patterns or long-term trends.

By mastering these concepts and exploring these examples, you’ll gain the skills to effectively leverage Matplotlib’s power and flexibility for generating insightful visualizations. These visualizations will not only aid in data analysis but also enhance your decision-making processes based on data-driven insights.

Congratulations on completing Day 9 of our Python for data science challenge! Today, you explored advanced data visualization techniques with Matplotlib, mastering bar plots, histograms, and subplots. Additionally, you learned how to add legends and annotations to create visually compelling and informative plots.

As you continue your Python journey, remember to leverage Matplotlib’s advanced functionalities to create rich and engaging visualizations. Tomorrow, on Day 10, we will dive into the art of exploratory data analysis (EDA), a crucial step in the data science workflow.

Let’s embark on this exciting journey together and unlock the power of data!

If you found this article interesting, your support by following steps will help me spread the knowledge to others:

👏 Give the article 50 claps

💻 Follow me on Twitter

📚 Read more articles on Medium|Linkedin|

--

--

Muhammad Dawood
Muhammad Dawood

Written by Muhammad Dawood

On a journey to unlock the potential of data-driven insights. Day Trader | FX & Commodity Markets | Technical Analysis & Risk Management Expert| Researcher

No responses yet