plotly.py icon indicating copy to clipboard operation
plotly.py copied to clipboard

Bar plot hover shows incorrect bar length when base is used

Open LarsDammannCoherent opened this issue 1 year ago • 1 comments

Hello,

I tried making something like a Gantt chart and use the Bar plot type for that. It seems the hover effect is mixing up the columns somehow. Here is a minimal reproduction:

import pandas as pd
import plotly.express as px

gantt = []
gantt.append(dict(Begin=0, End=1, Word='Foo'))
gantt.append(dict(Begin=2, End=5, Word='Bar'))
gantt_df = pd.DataFrame(gantt)
gantt_df['Duration'] = (gantt_df['End'] - gantt_df['Begin'])

fig = px.bar(gantt_df, base="Begin", y="Duration", x="Word")
fig.show()

Here is the result: image

Things of note:

  • The position and size of the bars is correct
  • The "Begin" annotation in the hover is correct
  • The "Duration" annotation shows the value of the "End" column, which is not correct. I would expect "End=5" or "Duration=3" but not "Duration=5"

Examining the pandas dataframe itself shows that the data itself is correct: image

This is my version according to conda: plotly 5.23.0 pyhd8ed1ab_0 conda-forge

Thank you for providing this great library for free and I hope that you find my report helpful.

LarsDammannCoherent avatar Aug 08 '24 12:08 LarsDammannCoherent

I figured out a workaround that works for me:

gantt_df['Duration'] = (gantt_df['End'] - gantt_df['Begin'])
fig = px.bar(gantt_df, base="Begin", x="Duration", y="Word", custom_data=['Begin', 'End', 'Duration', 'Word'])
fig.update_traces(
    hovertemplate="<br>".join([
        "Time: %{customdata[0]:.3f} - %{customdata[1]:.3f}",
        "Duration: %{customdata[2]:.3f}",
        "Word: %{customdata[3]}",
    ]) + "<extra></extra>"
)
fig.show()

Thanks to https://stackoverflow.com/questions/59057881/how-to-customize-hover-template-on-with-what-information-to-show

LarsDammannCoherent avatar Aug 20 '24 15:08 LarsDammannCoherent