Plotlyのcandlestickチャートでgapになっている期間をno gapで描画するの巻
data:image/s3,"s3://crabby-images/4f34a/4f34ac0d71f001122c11896575d4aa4a92c6e02c" alt="Plotlyのcandlestickチャートでgapになっている期間をno gapで描画するの巻"
はじめに
Plotlyでfxのチャートをそのまま描画すると、取引のない期間(日本では土曜の早朝から月曜日の早朝まで)はデータが無いためグラフにgapができてしまい不格好ですので。。。
data:image/s3,"s3://crabby-images/797c7/797c7f3d5969a031426c39a1e5b842cfc8d9d26f" alt="plotly_timegap"
↓のようにgapを非表示にして描画したい、と。そのやり方のメモです。
data:image/s3,"s3://crabby-images/c493c/c493cca295ab4dd4c74b8c54e67402ea7f253a01" alt="plotly_timegap_fixed"
方法としては、
rangebreaksを使ってgapとなっている期間を指定し非表示にする
にて、できることがわかりましたよ、と。
まずは普通に描画してみます
使用したデータ
次に示したpandasのDataFrameを使用します。
display(df)
data:image/s3,"s3://crabby-images/4a41a/4a41aad3e0173c590f15f6748036187054b224ab" alt="df_for_plotly_timegap"
・ドル円の1時間ごとのOHLCデータ
・期間:2020年8月14日(金)09:00 〜 2020年8月18日(火) 01:00
・8月15日が土曜日、8月16日が日曜日です
・gapとなっている期間は
2020-08-15 06:00:00 から 2020-08-17 06:00:00です
・datetimeとなっている列が真ん中にもありますが、index(DatetimeIndexにしています)のほうだけ使います。
Plotlyでローソク足チャートを描画してみます(Gap修正前)
#plotlyで視覚化。
import plotly.express as px
import plotly.graph_objects as go
fig = go.Figure(data = [
go.Candlestick(
x = df.index,
open = df['Open'],
high = df['High'],
low = df['Low'],
close = df['Close'],
name = 'USD/JPY 1 hr')
])
#range sliderをoff
fig.update_layout(
xaxis_rangeslider_visible=False
)
fig.show()
data:image/s3,"s3://crabby-images/797c7/797c7f3d5969a031426c39a1e5b842cfc8d9d26f" alt="plotly_timegap"
と、このように取引が無い期間についてはgapができてしまいます。
Gapのある期間をno gapで描画するやりかた
手順としては、gapとなっている期間のリストを作成し、rangebreaksのvaluesで指定してから描画します。
使用したデータは先ほどのdfです。
data:image/s3,"s3://crabby-images/4a41a/4a41aad3e0173c590f15f6748036187054b224ab" alt="df_for_plotly_timegap"
Gapとなっている期間のリストを作成する
まず、gapとなっている期間のリストを作成します。
"""
gapとなっている時間を抽出し、リスト名timegapとして取得する
"""
df_resample = df.resample('H').max() #gapの期間中を1時間単位で補間したDataFrameを取得。max()は便宜上入れています。
merged_index = df.index.append(df_resample.index) #元々のindexとまとめてgapの時間以外を重複要素としてやる
timegap = merged_index[~merged_index.duplicated(keep = False)] #重複要素を除去することでgapとなっている時間を抽出する
display(timegap)
DatetimeIndex(['2020-08-15 06:00:00', '2020-08-15 07:00:00', '2020-08-15 08:00:00', '2020-08-15 09:00:00', '2020-08-15 10:00:00', '2020-08-15 11:00:00', '2020-08-15 12:00:00', '2020-08-15 13:00:00', '2020-08-15 14:00:00', '2020-08-15 15:00:00', '2020-08-15 16:00:00', '2020-08-15 17:00:00', '2020-08-15 18:00:00', '2020-08-15 19:00:00', '2020-08-15 20:00:00', '2020-08-15 21:00:00', '2020-08-15 22:00:00', '2020-08-15 23:00:00', '2020-08-16 00:00:00', '2020-08-16 01:00:00', '2020-08-16 02:00:00', '2020-08-16 03:00:00', '2020-08-16 04:00:00', '2020-08-16 05:00:00', '2020-08-16 06:00:00', '2020-08-16 07:00:00', '2020-08-16 08:00:00', '2020-08-16 09:00:00', '2020-08-16 10:00:00', '2020-08-16 11:00:00', '2020-08-16 12:00:00', '2020-08-16 13:00:00', '2020-08-16 14:00:00', '2020-08-16 15:00:00', '2020-08-16 16:00:00', '2020-08-16 17:00:00', '2020-08-16 18:00:00', '2020-08-16 19:00:00', '2020-08-16 20:00:00', '2020-08-16 21:00:00', '2020-08-16 22:00:00', '2020-08-16 23:00:00', '2020-08-17 00:00:00', '2020-08-17 01:00:00', '2020-08-17 02:00:00', '2020-08-17 03:00:00', '2020-08-17 04:00:00', '2020-08-17 05:00:00', '2020-08-17 06:00:00'], dtype='datetime64[ns]', name='datetime', freq=None)
見にくいですがgapとなっていた期間(2020-08-15 06:00:00から2020-08-17 06:00:00)のリストができました。
Plotlyでローソク足チャートを描画してみます(no gapで)
先ほど作成したリストをrangebreaksのvaluesにあてがってから描画します。
コードに
fig.update_xaxes( rangebreaks=[ dict(values = timegap, dvalue = 3600000) ])
を追加します。
なお、1時間ごとのデータなので、dvalueを3600000 msec(1 hr)に設定しています。時系列の間隔に合わせてdvalueを設定すれば良いです。
なお、dvalueのデフォルト値は86400000 msecで24 hrとなっていますので、日足データの場合はdvalueの変更は必要ないかと思います。
#plotlyで視覚化。
import plotly.express as px
import plotly.graph_objects as go
from plotly.subplots import make_subplots
fig = go.Figure(data = [
go.Candlestick(
x = df_chart_partial.index,
open = df_chart_partial['Open'],
high = df_chart_partial['High'],
low = df_chart_partial['Low'],
close = df_chart_partial['Close'],
name = 'USD/JPY 1 hr')
])
"""
X軸において、rangebreaksのvaluesにgapとなっている期間のデータポイントのリストを設定することで非表示にする。
"""
fig.update_xaxes(
rangebreaks=[
dict(values = timegap, dvalue = 3600000)
])
#range sliderをoff
fig.update_layout(
xaxis_rangeslider_visible=False
)
fig.show()
data:image/s3,"s3://crabby-images/c493c/c493cca295ab4dd4c74b8c54e67402ea7f253a01" alt="plotly_timegap_fixed"
該当箇所(2020-08-15 05:00と2020-08-17 07:00)を拡大してみます。
data:image/s3,"s3://crabby-images/d2c04/d2c04e14e438ef4a05504ee5a9dd52a4cb9b778d" alt="plotly_timegap_fixed_zoom"
でけた。めでたしめでたし。
環境
この記事の内容は
Python; 3.7.2
Plotly; 4.9.0
pandas; 1.0.5
jupyter; 1.0.0
にて実施しました。
このブログはエックスサーバー
data:image/s3,"s3://crabby-images/6ccef/6ccef1904126e85e9499e580aa90d9cf19edbaa9" alt=""
data:image/s3,"s3://crabby-images/6324f/6324fb9ed7a47b4cd3ba47abe6ad8dc8aa0cfd30" alt=""
WordPressを使うならロリポップ!
簡単インストール完備で楽々スタート!
data:image/s3,"s3://crabby-images/14d93/14d9331bca687f98b4d16967ec7dd48af266fe63" alt=""
世界にたった一つ、あなただけのドメインを登録しよう!
格安ドメイン取得サービス─ムームードメイン─
data:image/s3,"s3://crabby-images/6ce32/6ce32812bc1bbe31599812f5f568c2854b53f66d" alt=""