lan*_*ayz 5 python plotly plotly-dash plotly-python
我使用下面的代码在 plotly dash 上显示 x 和 y 值。但是我希望能够在“值”文本字段下方添加另一个文本字段。
文本字段将被称为“类别”,因此如果显示的 y 值是:5k,则类别 = 不贵,或者如果值为 20k,则类别 = 平均价格,如果值为 30k,则类别 = 太贵。
我将如何实现这一点?这是显示悬停在其上的值的运行代码
import json
from textwrap import dedent as d
import pandas as pd
import plotly.graph_objects as go
import numpy as np
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.express as px
from dash.dependencies import Input, Output
from jupyter_dash import JupyterDash
# app info
app = JupyterDash(__name__)
styles = {
'pre': {
'border': 'thin lightgrey solid',
'overflowX': 'scroll'
}
}
# data and basic figure
x = np.arange(20)+10
fig = go.Figure(data=go.Scatter(x=x, y=x**2, mode = 'lines+markers'))
fig.add_traces(go.Scatter(x=x, y=x**2.2, mode = 'lines+markers'))
app.layout = html.Div([
dcc.Graph(
id='basic-interactions',
figure=fig,
),
html.Div(className='row', children=[
html.Div([
dcc.Markdown(d("""
Click on points in the graph.
""")),
html.Pre(id='hover-data', style=styles['pre']),
], className='three columns'),
])
])
@app.callback(
Output('hover-data', 'children'),
[Input('basic-interactions', 'hoverData')])
def display_hover_data(hoverData):
return json.dumps(hoverData, indent=2)
app.run_server(mode='external', port = 8070, dev_tools_ui=True,
dev_tools_hot_reload =True, threaded=True)
Run Code Online (Sandbox Code Playgroud)
对您的设置进行以下修改:
if hoverData['points'][0]['y'] >= 5000:
Category = 'not Pricey'
if hoverData['points'][0]['y'] >= 20000:
Category = 'average price'
if hoverData['points'][0]['y'] >= 30000:
Category = 'Too pricey'
output = json.dumps({'Date:':hoverData['points'][0]['x'],
'Value:':hoverData['points'][0]['y'],
'Category':Category
}, indent = 2)
Run Code Online (Sandbox Code Playgroud)
...下面的代码片段生成以下应用程序:
您没有为低于5000 的值指定类别,因此现在仅返回空字符串。尝试一下,让我知道这对您来说效果如何。
import json
from textwrap import dedent as d
import pandas as pd
import plotly.graph_objects as go
import numpy as np
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.express as px
from dash.dependencies import Input, Output
from jupyter_dash import JupyterDash
# app info
app = JupyterDash(__name__)
styles = {
'pre': {
'border': 'thin lightgrey solid',
'overflowX': 'scroll'
}
}
# data and basic figure
y = np.arange(100)+20
x = pd.date_range(start='1/1/2021', periods=len(y))
fig = go.Figure(data=go.Scatter(x=x, y=y**2, mode = 'lines+markers'))
fig.add_traces(go.Scatter(x=x, y=y**2.2, mode = 'lines+markers'))
app.layout = html.Div([
dcc.Graph(
id='basic-interactions',
figure=fig,
),
html.Div(className='row', children=[
html.Div([
dcc.Markdown(d("""
Click on points in the graph.
""")),
html.Pre(id='hover-data', style=styles['pre']),
], className='three columns'),
])
])
# The text field would be called "Category" so that if the y value displayed is:
# 5k then category = not pricey or if value is 20k then category = average price and
# if value is 30k then category = too pricey.
@app.callback(
Output('hover-data', 'children'),
[Input('basic-interactions', 'hoverData')])
def display_hover_data(hoverData):
global hd
hd = hoverData
Category = ''
try:
output = json.dumps({'Date:':hoverData['points'][0]['x'],
'Value:':hoverData['points'][0]['y']}, indent = 2)
if hoverData['points'][0]['y'] >= 5000:
Category = 'not Pricey'
if hoverData['points'][0]['y'] >= 20000:
Category = 'average price'
if hoverData['points'][0]['y'] >= 30000:
Category = 'Too pricey'
output = json.dumps({'Date:':hoverData['points'][0]['x'],
'Value:':hoverData['points'][0]['y'],
'Category':Category
}, indent = 2)
print(output)
return output
except:
return None
app.run_server(mode='external', port = 8070, dev_tools_ui=True,
dev_tools_hot_reload =True, threaded=True)
Run Code Online (Sandbox Code Playgroud)