使用下拉菜单将两个不同的数据集绘制成图

时间:2019-04-29 16:39:16

标签: python plotly

我有两个不同的数据集(x0,y0),(x1,y1)。我需要创建两个图并使用下拉菜单在它们之间进行选择。

我正在使用以下代码:

import plotly
import plotly.graph_objs as go
import random

x0 = [x for x in range(0,20)]
x1 = [x for x in range(5,100)]

y0 = [random.randint(0,20) for x in range(len(x0))]
y1 = [random.randint(0,50) for x in range(len(x1))]

trace1 = go.Scatter(x=x0,y=y0,line=dict(shape='vh'))
trace2 = go.Scatter(x=x1,y=y1,line=dict(shape='vh'))

data = [trace1,trace2]

updatemenus = list([
    dict(active=0,
         buttons=list([   
            dict(label = "4 Aug 1",
                 method = "update",
                 args= [data[0]]),
            dict(label = "4 Aug 2",
                 method = "update",
                 args= [data[1]])]))])


layout = dict(title="Dropdown",
              showlegend=True,
              xaxis=dict(title="Hours"),
              yaxis=dict(title="Number"),
              updatemenus=updatemenus)

fig=dict(data=data, layout=layout)

plotly.offline.plot(fig)

使用此代码,它将两个数据集绘制到一个区域中,我不希望这样做。而且,当我在下拉菜单中选择适当的图表时,它只是无法加载适当的图表。

1 个答案:

答案 0 :(得分:1)

问题是您直接将跟踪分配给args。相反,您应该使用visible属性来控制data中的哪些迹线可见:

updatemenus = list([
    dict(active=0,
         showactive = True,
         buttons=list([   
            dict(label = "4 Aug 1",
                 method = "update",
                 args = [{"visible": [True, False]}]), # hide trace2
            dict(label = "4 Aug 2",
                 method = "update",
                 args = [{"visible": [False, True]}]) # hide trace1
            ]))])

如果只想在页面加载时显示第一条迹线,则还需要将第二条迹线的visible属性显式设置为False

trace1 = go.Scatter(x=x0,y=y0,line=dict(shape='vh'))
trace2 = go.Scatter(x=x1,y=y1,line=dict(shape='vh'), visible=False)
data = [trace1,trace2]

请参见official Plotly example