Jump into concepts and practice - no test required
or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Interactive Hover Labels with Mplcursors in Matplotlib
📖 Scenario: You are analyzing sales data for a small store. You want to create a simple scatter plot of sales over days and add interactive hover labels to see exact values when you move the mouse over points.
🎯 Goal: Create a scatter plot using matplotlib and add interactive hover labels using mplcursors to display the exact sales value when hovering over each point.
📋 What You'll Learn
Create a dictionary called sales_data with days as keys and sales as values
Create a list called days containing the keys from sales_data
Create a list called sales containing the values from sales_data
Plot a scatter plot of days vs sales using matplotlib.pyplot.scatter
Use mplcursors.cursor to add hover labels showing sales values
Print the plot with interactive hover labels
💡 Why This Matters
🌍 Real World
Interactive plots help analysts explore data visually and get exact values easily without cluttering the graph.
💼 Career
Data scientists and analysts often use interactive visualizations to communicate insights clearly and allow users to explore data points.
Progress0 / 4 steps
1
Create the sales data dictionary
Create a dictionary called sales_data with these exact entries: 1: 150, 2: 200, 3: 170, 4: 220, 5: 180
Matplotlib
Hint
Use curly braces {} to create a dictionary with keys as days and values as sales.
2
Extract days and sales lists
Create a list called days containing the keys from sales_data and a list called sales containing the values from sales_data
Matplotlib
Hint
Use list() with sales_data.keys() and sales_data.values() to get the lists.
3
Plot scatter and add mplcursors hover labels
Import matplotlib.pyplot as plt and mplcursors. Plot a scatter plot of days vs sales using plt.scatter(days, sales). Then use mplcursors.cursor() on the scatter plot to add hover labels showing sales values.
Matplotlib
Hint
Use plt.scatter() to plot points and mplcursors.cursor() with hover=True to enable hover labels.
4
Display the plot with hover labels
Add plt.show() to display the scatter plot with interactive hover labels.
Matplotlib
Hint
Use plt.show() to open the plot window with interactive hover labels.
Practice
(1/5)
1. What is the main purpose of using mplcursors in matplotlib plots?
easy
A. To save the plot as an image file
B. To change the color of the plot lines
C. To add interactive hover labels showing data values
D. To create 3D plots automatically
Solution
Step 1: Understand mplcursors functionality
mplcursors is a tool that adds interactive hover labels to matplotlib plots, showing data values when you hover over points.
Step 2: Compare options with mplcursors purpose
Changing colors, saving images, or creating 3D plots are not related to hover labels, so only adding interactive hover labels fits.
Final Answer:
To add interactive hover labels showing data values -> Option C
Quick Check:
mplcursors = interactive hover labels [OK]
Hint: Remember mplcursors = hover labels for data points [OK]
Common Mistakes:
Confusing mplcursors with plot styling tools
Thinking mplcursors saves files
Assuming mplcursors creates 3D plots
2. Which of the following is the correct way to import mplcursors for use in a matplotlib plot?
easy
A. import mplcursors
B. from matplotlib import mplcursors
C. import matplotlib.mplcursors
D. import mpl_cursor
Solution
Step 1: Recall correct import syntax
The mplcursors library is a separate package and is imported simply with import mplcursors.
Step 2: Check other options for errors
from matplotlib import mplcursors is wrong because mplcursors is not part of matplotlib. import matplotlib.mplcursors is wrong because it's a separate package, not a submodule. import mpl_cursor is incorrect because the module name is mplcursors, not mpl_cursor.
Final Answer:
import mplcursors -> Option A
Quick Check:
Correct import = import mplcursors [OK]
Hint: Use simple import: import mplcursors [OK]
Common Mistakes:
Trying to import mplcursors from matplotlib
Thinking mplcursors is matplotlib.mplcursors submodule
Using wrong module name like mpl_cursor
3. What will be the output behavior of this code snippet?
A. Plot shows points with hover labels displaying (x, y) values
B. Plot shows points but no hover labels appear
C. Code raises an error because cursor() needs extra arguments
D. Plot shows a line connecting points without markers
Solution
Step 1: Understand code components
The code plots points at (1,4), (2,5), (3,6) with markers 'o'. Then mplcursors.cursor(points) adds interactive hover labels.
Step 2: Predict output behavior
When running plt.show(), the plot appears with points. Hovering over points shows labels with their coordinates because mplcursors is activated correctly.
Final Answer:
Plot shows points with hover labels displaying (x, y) values -> Option A
A. The variable 'line' should be a list, not a single Line2D object
B. The plot command is missing marker style to show points
C. mplcursors is not imported correctly
D. mplcursors.cursor() must be called before plotting
Solution
Step 1: Analyze plot and cursor usage
The code plots a line without markers. Hover labels appear on points, but here points are not visible because no markers are set.
Step 2: Identify why hover labels don't show
mplcursors works on plotted points. Without markers, the line is continuous and no discrete points exist to hover on, so labels don't appear.
Final Answer:
The plot command is missing marker style to show points -> Option B
Quick Check:
Missing markers = no hover labels [OK]
Hint: Add markers to plot for mplcursors hover labels [OK]
Common Mistakes:
Thinking mplcursors must be called before plot
Assuming single Line2D object is invalid input
Believing import error causes no labels
5. You want to show hover labels only for points where y > 5 in this plot. Which code change achieves this?
import matplotlib.pyplot as plt
import mplcursors
fig, ax = plt.subplots()
x = [1, 2, 3, 4]
y = [4, 5, 6, 7]
points = ax.plot(x, y, 'o')
# Add hover labels only for y > 5
mplcursors.cursor(points)
hard
A. Use mplcursors.cursor(points).remove() for points with y <= 5
B. Filter points before plotting: ax.plot([xi for xi, yi in zip(x,y) if yi>5], [yi for yi in y if yi>5], 'o')
C. Set cursor with mplcursors.cursor(points, hover=True, filter=lambda sel: sel.target[1] > 5)
D. Use mplcursors.cursor(points).connect('add', lambda sel: sel.annotation.set_visible(sel.target[1] > 5))
Solution
Step 1: Understand how to filter hover labels
mplcursors allows connecting to events like 'add' to customize annotation visibility based on data values.
Step 2: Analyze options for filtering by y > 5
Use mplcursors.cursor(points).connect('add', lambda sel: sel.annotation.set_visible(sel.target[1] > 5)) uses a lambda to set annotation visible only if y > 5, which is correct. Filter points before plotting: ax.plot([xi for xi, yi in zip(x,y) if yi>5], [yi for yi in y if yi>5], 'o') filters points before plotting but does not use mplcursors filtering. Set cursor with mplcursors.cursor(points, hover=True, filter=lambda sel: sel.target[1] > 5) uses a non-existent 'filter' argument. Use mplcursors.cursor(points).remove() for points with y <= 5 tries to remove cursor which is not valid for selective filtering.
Final Answer:
Use mplcursors.cursor(points).connect('add', lambda sel: sel.annotation.set_visible(sel.target[1] > 5)) -> Option D
Quick Check:
Connect 'add' event to filter hover labels [OK]
Hint: Use cursor.connect('add', lambda sel: condition) to filter labels [OK]