Python Plotly如何删除蜡烛图中的日期间隔?

kqhtkvqz  于 2023-02-18  发布在  Python
关注(0)|答案(4)|浏览(233)

我正在尝试删除烛台中的日期间隔(这些间隔是股市收盘的时间段,因此没有数据)。似乎找不到一个好的解决方案来使用plotly graph对象。有可行的方法吗?

我的代码如下(使用plotly graph对象):

import dash
import dash_core_components as dcc
import dash_table
import pandas as pd
import dash_html_components as html
import numpy as np
from dash.dependencies import Output, Input, State
import plotly.graph_objects as go
import yfinance as yf
import plotly.express as px
from datetime import datetime, timedelta
from pytz import timezone
import dash_bootstrap_components as dbc

df= yf.Ticker('aapl')
df = df.history(interval="5m",period="5d")
df["Datetime"] = df.index

trace1 = {
    'x': df.Datetime,
    'open': df.Open,
    'close': df.Close,
    'high': df.High,
    'low': df.Low,
    'type': 'candlestick',
    'name': 'apple,
    'showlegend': False
    }

data = [trace1]

# Config graph layout
layout = go.Layout({
        'title': {
            'text': str(input_value) + ' Stock',
            'font': {
                'size': 15
            }
        },
        'plot_bgcolor': '#2E2E2E'
    })
fig = go.Figure(data=data, layout=layout)
fig.update_layout(xaxis_rangeslider_visible=False)

if __name__ == '__main__':
    app.run_server(debug=True)
ergxz8rk

ergxz8rk1#

你可以通过范围转折来达到这个目的。
下面是隐藏交易时间和周末以外的代码。

fig = go.Figure(data=[go.Candlestick(x=df['date'], open=df['Open'], high=df['High'], low=df['Low'], close=df['Close'])])
    fig.update_xaxes(
        rangeslider_visible=True,
        rangebreaks=[
            # NOTE: Below values are bound (not single values), ie. hide x to y
            dict(bounds=["sat", "mon"]),  # hide weekends, eg. hide sat to before mon
            dict(bounds=[16, 9.5], pattern="hour"),  # hide hours outside of 9.30am-4pm
            # dict(values=["2019-12-25", "2020-12-24"])  # hide holidays (Christmas and New Year's, etc)
        ]
    )
    fig.update_layout(
        title='Stock Analysis',
        yaxis_title=f'{symbol} Stock'
    )

    fig.show()

这是Plotly医生

cwtwac6a

cwtwac6a2#

您可以设置rangebreaks选项:
1.你必须找到missing值(假日,周末,休息日等)
您可以使用以下两行代码
1.将fig.update放在fig.show()之前。

alldays =set(df.Datetime[0]+timedelta(x) for x in range((df.Datetime[len(df.Datetime)-1]- df.Datetime[0]).days))
missing=sorted(set(alldays)-set(df.Datetime))

fig.update_xaxes(rangebreaks=[dict(values=missing)])
h9vpoimq

h9vpoimq3#

TLDR:我遇到了同样的问题,在plotly的文档中找不到任何解决方案。我在plotly R社区找到的唯一建议是将x轴作为类别而不是日期时间。但我仍然无法让它工作,因为fig.layout()没有这样的属性可用。
对于您的代码,将Datetime更改为字符串,以强制其为非datetime类型轴

df["Datetime"] = df.index.dt.strftime("%Y/%m/%d %H:%M")

这应该可以解决日期时间间隔的问题。

fykwrbwg

fykwrbwg4#

我们可以设置rangebreaks选项:
1.填充具有间隙的nan(即,重新索引 Dataframe );
1.为所有nan值创建datebreaks;
1.在xaxes配置上设置范围中断值

begin_date, end_date = [df.iloc[0].name, df.iloc[-1].name]
df = df.reindex(pd.date_range(begin_date, end_date, freq='D'))
datebreaks = df['Close'][df_plot['Close'].isnull()].index
fig.update_xaxes(rangebreaks=[dict(values=datebreaks)])

相关问题