Ami*_*mir 8 python plotly plotly-dash
我想在 plotly dash 中绘制一个带有两个子图的图表。我的整个图表如下所示:
import pandas as pd
import numpy as np
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.graph_objs as go
from plotly.subplots import make_subplots
df = pd.read_csv('https://raw.githubusercontent.com/plotly/datasets/master/finance-charts-apple.csv').iloc[:60]
fig = make_subplots(rows=2, cols=1, row_heights=[0.8, 0.2], vertical_spacing=0)
fig.add_trace(go.Candlestick(open=df['AAPL.Open'], high=df['AAPL.High'], low=df['AAPL.Low'], close=df['AAPL.Close'],
increasing_line_color='#0384fc', decreasing_line_color='#e8482c', name='AAPL'), row=1, col=1)
fig.add_trace(go.Scatter(y=np.random.randint(20, 40, len(df)), marker_color='#fae823', name='VO', hovertemplate=[]), row=2, col=1)
fig.update_layout({'plot_bgcolor': "#21201f", 'paper_bgcolor': "#21201f", 'legend_orientation': "h"},
legend=dict(y=1, x=0),
font=dict(color='#dedddc'), dragmode='pan', hovermode='x unified',
margin=dict(b=20, t=0, l=0, r=40))
fig.update_xaxes(showgrid=False, zeroline=False, rangeslider_visible=False, showticklabels=False,
showspikes=True, spikemode='across', spikesnap='data', showline=False, spikedash='solid')
fig.update_yaxes(showgrid=False, zeroline=False)
fig.update_traces(xaxis='x', hoverinfo='none')
app = dash.Dash(__name__)
app.layout = html.Div(children=[
html.Div(dcc.Graph(id='chart', figure=fig, config={'displayModeBar': False}))])
if __name__ == '__main__':
app.run_server(debug=True, dev_tools_ui=False, dev_tools_props_check=False)
Run Code Online (Sandbox Code Playgroud)
我需要的是交易图表中常见的所谓十字准线。基本上它由连接到 x 和 y 轴并随光标移动的两条线组成。这是来自 tradeview.com 图表的屏幕截图:

到目前为止我发现的是,当光标位于散点图上时,图标消失并且工作正常。我想那是因为我hovertemplate=[]在散点图中设置了。我不能在烛台图中这样做,因为它没有这样的参数。此外,此图标仅在我设置hovermode='x unified'. 如果我将其设置为 x,则不会出现小图标。但我需要它与我展示的 tradeview.com 示例完全一样。有没有办法复制那个十字准线?
更新1:
我试过了fig.update_layout(hoverdistance=0)。但问题是,当光标不在烛台上时,十字准线就是不对的。我截取了两张截图:第一张来自 Tradingview.com 图表,第二张来自我hoverdistance设置为 0 的代码。
可以看出,当光标不在烛台上时,在第一个屏幕截图中,十字准线仍然正确。但是,在第二个屏幕截图中,它无法正常工作。仅当光标位于烛台上时才有效。我只想复制tradingview.com 的十字准线。仅此而已。
更新 2:
我认为答案可能就在这些复杂的文档上。我目前正在研究它。请分享您对此更新的意见。
这应该这样做:
fig.update_layout(hoverdistance=0)
Run Code Online (Sandbox Code Playgroud)
并设置spikesnap='cursor'xaxes 和 yaxes。
这些小调整将保持十字准线完好无损,并删除一直困扰您的小图标。
从文档:
阴谋:
悬停距离
设置默认距离(以像素为单位)以查找数据以添加悬停标签(-1 表示不截断,0 表示不查找数据)。这只是悬停在点状物体(如散点)上的真实距离。对于类似区域的对象(条形、散点填充等),在区域内悬停在区域内,在区域外悬停,但在发生冲突时,这些对象不会取代点状对象上的悬停。
完整代码:(但没有破折号元素)
import pandas as pd
import numpy as np
import plotly.graph_objs as go
from plotly.subplots import make_subplots
df = pd.read_csv('https://raw.githubusercontent.com/plotly/datasets/master/finance-charts-apple.csv').iloc[:60]
fig = make_subplots(rows=2, cols=1, row_heights=[0.8, 0.2], vertical_spacing=0)
fig.add_trace(go.Candlestick(open=df['AAPL.Open'], high=df['AAPL.High'], low=df['AAPL.Low'], close=df['AAPL.Close'],
increasing_line_color='#0384fc', decreasing_line_color='#e8482c', name='AAPL'), row=1, col=1)
fig.add_trace(go.Scatter(y=np.random.randint(20, 40, len(df)), marker_color='#fae823', name='VO', hovertemplate=[]), row=2, col=1)
fig.update_layout({'plot_bgcolor': "#21201f", 'paper_bgcolor': "#21201f", 'legend_orientation': "h"},
legend=dict(y=1, x=0),
font=dict(color='#dedddc'), dragmode='pan', hovermode='x unified',
margin=dict(b=20, t=0, l=0, r=40))
fig.update_yaxes(showgrid=False, zeroline=False, showticklabels=False,
showspikes=True, spikemode='across', spikesnap='cursor', showline=False, spikedash='solid')
fig.update_xaxes(showgrid=False, zeroline=False, rangeslider_visible=False, showticklabels=False,
showspikes=True, spikemode='across', spikesnap='cursor', showline=False, spikedash='solid')
fig.update_layout(hoverdistance=0)
fig.update_traces(xaxis='x', hoverinfo='none')
fig.show()
Run Code Online (Sandbox Code Playgroud)
如果你设置,hovermode='x'那么你可以像这样设置尖峰线的样式:
fig.update_xaxes(spikecolor="grey",spikethickness=1)
Run Code Online (Sandbox Code Playgroud)
更新:
spikesnap='cursor'会让你更接近,但不完全适用于烛台。
fig.update_xaxes(showgrid=False, zeroline=False, rangeslider_visible=False, showticklabels=False,
showspikes=True, spikemode='across', spikesnap='cursor', showline=False,
spikecolor="grey",spikethickness=1, spikedash='solid')
fig.update_yaxes(showspikes=True, spikedash='solid',spikemode='across',
spikecolor="grey",spikesnap="cursor",spikethickness=1)
fig.update_layout(spikedistance=1000,hoverdistance=1000)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4378 次 |
| 最近记录: |