Создать выпадающее меню в плотно - PullRequest
0 голосов
/ 15 сентября 2018

У меня есть следующий фрейм данных:

# Create DataFrame
df = pd.DataFrame({"Col_A_date":[2018-09-04,2018-09-05,2018-09-04,2018-09-05],
                   "Col_B_hour":[7,7,8,8],
                   "Col_C":[1,1,2,2],
                    "Col_value":[1.9,2.2,2.6,3.8]
                   })

Я хочу создать график, в котором col_A отображается как выпадающие меню (2018-09-04 и 2018-09-05), Col_B - это ось x, Col_value - это ось y, а Col_C - как трассы . Таким образом, я могу видеть данные для разных дат на одном графике. Можно ли сделать с помощью сюжета?

1 Ответ

0 голосов
/ 16 сентября 2018

Да, это возможно. Обновлено с вашими объяснениями. Если я правильно понимаю, что вам нужно, то этот код работает, что вы хотите:

# import libraries
import pandas as pd
import plotly
import plotly.graph_objs as go

# Create DataFrame
df = pd.DataFrame({"Col_A_date":["2018-09-04","2018-09-05","2018-09-04","2018-09-05"],
                   "Col_B_hour":[7,7,8,8],
                   "Col_C":[1,1,2,2],
                   "Col_value":[1.9,2.2,2.6,3.8]
                   })
# create four df for traces
df1 = df.loc[(df["Col_A_date"] == "2018-09-04") & (df["Col_C"] == 1)]
df2 = df.loc[(df["Col_A_date"] == "2018-09-04") & (df["Col_C"] == 2)]
df3 = df.loc[(df["Col_A_date"] == "2018-09-05") & (df["Col_C"] == 1)]
df4 = df.loc[(df["Col_A_date"] == "2018-09-05") & (df["Col_C"] == 2)]
print(df1,df2,df3,df4)
# Create traces
trace1 = go.Bar(x=list(df1["Col_B_hour"]),
                y=list(df1["Col_value"]),
                name="1",
                text = list(df1["Col_value"]),
                textposition="auto",
                hoverinfo="name",
                marker=dict(color="rgb(0,102,204)")
                )
trace2 = go.Bar(x=list(df2["Col_B_hour"]),
                y=list(df2["Col_value"]),
                name="2",
                text=list(df2["Col_value"]),
                textposition="auto",
                hoverinfo="name",
                marker=dict(color="rgb(255,128,0)")
                )
trace3 = go.Bar(x=list(df3["Col_B_hour"]),
                y=list(df3["Col_value"]),
                name="3",
                text = list(df3["Col_value"]),
                textposition="auto",
                hoverinfo="name",
                marker=dict(color="rgb(255,178,102)")
                )
trace4 = go.Bar(x=list(df4["Col_B_hour"]),
                y=list(df4["Col_value"]),
                name="4",
                text=list(df4["Col_value"]),
                textposition="auto",
                hoverinfo="name",
                marker=dict(color="rgb(255,255,153)")
                )
# Pull traces to data
data = [trace1,trace2,trace3,trace4]
# Specify dropout parameters
updatemenus = list([
    dict(active=-1,
         buttons=list([   
            dict(label = "4 Aug 1",
                 method = "update",
                 args = [{"visible": [True, False, False, False]},
                         {"title": "4 Aug 1"}]),
            dict(label = "4 Aug 2",
                 method = "update",
                 args = [{"visible": [False, True, False, False]},
                         {"title": "4 Aug 2"}]),
            dict(label = "5 Aug 1",
                 method = "update",
                 args = [{"visible": [False, False, True, False]},
                         {"title": "5 Aug 1"}]),
            dict(label = "5 Aug 2",
                 method = "update",
                 args = [{"visible": [False, False, False, True]},
                         {"title": "5 Aug 2"}]),
            dict(label = "All",
                 method = "update",
                 args = [{"visible": [True, True, True, True]},
                         {"title": "All"}]),
            dict(label = "Reset",
                 method = "update",
                 args = [{"visible": [False, False, False, False]},
                         {"title": "Reset"}])
        ]),
    )
])
# Set layout
layout = dict(title="Dropdown",
              showlegend=False,
              xaxis=dict(title="Hours"),
              yaxis=dict(title="Number"),
              updatemenus=updatemenus)
# Create fig
fig = dict(data=data, layout=layout)
# Plot the plotly plot
plotly.offline.plot(fig, filename="update_dropdown.html")

Вот как выглядит выбор All: all И сначала trace: First trace Вот несколько полезных ссылок из документации: о гистограммах ; текст при наведении ; выпадающее меню . Не бойтесь смотреть на заговор документацию - есть отличные примеры того, как правильно использовать этот пакет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...