🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

1回答

4330閲覧

seaborn.relplotでX軸を時系列にしたときの範囲(xlim)の指定方法

Kumazaemon

総合スコア5

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2021/01/14 07:22

編集2021/01/14 09:04

pandasのDataFrameで、時系列と数値列とによるdfを作成し、seaborn.relplotで描画しました。
dfはこんなのです。

col
2020-01-0110
2020-01-0220
import pandas as pd import seaborn as sns df = pd.DataFrame([10,20],index=pd.to_datetime(['20200101','20200102']), columns=['col']) g = sns.relplot(data=df)

すると、実際に含まれる2020年からは大きく異なり、2000年を下限とする広範囲のX領域で表示されてしまいました。
なお、dfの時系列カラムのdtypeが、'datetime64[ns]'になっていることを確認済みです。

イメージ説明

そこで、axesのxlimを使って範囲を指定しようとしたのですが、時系列データの指定方法が分かりません。

考えたこと1:ax.xlimで2019年12月31日と2020年1月3日などが設定できればよい。

でも、データフレームではないので、pd.to_datetimeが使えず、どうすればよいか見通しが立ちません

g.ax.set_xlim(starttime,endtime)
考えたこと2:作られているグラフの範囲をgetすれば逆算の参考になるかも。

そこで、

g.ax.get_xlim()

としたら、
(729754.7, 737791.3)
がかえってきました。これが2000年頃と、2020年頃を指しているのですね…。
型は'numpy.float64'でした。
しかし、どうやったら2020年1月3日というような日にちからこの数字を求められるかわからず、次に進めません。
numpy.datetime64で調べましたが、このようなfloat64のフォーマットについての記述を見つけることができませんでした。

以上二つの考えたことの次のステップのアドバイスを頂けるとありがたいです。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kirara0048

2021/01/14 08:28

書かれているコードでも同様の事象が起きるのでしょうか。再現されるコードを書いてください。 `df.index`の最小値と最大値は確認しましたでしょうか。 図の最小値最大値は`mpl.dates.num2date(g.ax.get_xlim())`で確認してみてください。
Kumazaemon

2021/01/14 08:50

kirara0048さん、ありがとうございます! はい、こちらのコードで同様の事象が起こります。 (すみません、質問当初のグラフ画像には4つプロットがありましたが、現象の起こる最小のdfにして投稿したため、コードとの齟齬が生じていました。正しい画像に修正しました) dx.indexの最小値と最大値は Timestamp('2020-01-01 00:00:00') Timestamp('2020-01-02 00:00:00') で、dfの作成意図のとおりに認識されています。 教えていただいた図の最小と最大ですが、 [datetime.datetime(1998, 12, 31, 16, 48, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 1, 1, 7, 12, tzinfo=datetime.timezone.utc)] と出てきました。 ほぼグラフの目視認識と近いです。
guest

回答1

0

ベストアンサー

時系列データの可視化:datetime型のx軸操作を参考に設定してみました。

python

1import pandas as pd 2import seaborn as sns 3from matplotlib.dates import drange 4import datetime 5from matplotlib.dates import DateFormatter 6import matplotlib.pyplot as plt 7import matplotlib.ticker as ticker 8from matplotlib.dates import date2num 9 10df = pd.DataFrame([10,20],index=pd.to_datetime(['20200101','20200102']), columns=['col']) 11x = drange(min(df.index), max(df.index) + datetime.timedelta(days=1), datetime.timedelta(days=1)) 12x2 = date2num([min(df.index), max(df.index)]) 13 14g = sns.relplot(data=df, x=x, y='col') 15g.ax.xaxis.set_major_locator(ticker.FixedLocator(x2)) 16g.ax.xaxis.set_major_formatter(DateFormatter('%Y-%m-%d')) 17g.ax.set_xlabel('date') 18plt.show()

イメージ説明

投稿2021/01/14 11:08

meg_

総合スコア10739

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Kumazaemon

2021/01/15 01:53

meg_さん、今回もありがとうございます。 無事希望の範囲指定ができました! また、ご提示いただいたサイトから、float64が >0001年1月1日を1としたときの日数 らしいことが分かり、とても助かりました。 細かいレイアウトに注文をつけなければ、この数値に換算して対応することもできそうです。
Kumazaemon

2021/01/15 02:06

↑の続きです。 もとのコードに、 g.ax.set_xlim(737424,737427) #2019年12月31日から2020年1月3日まで とすると、無事範囲が指定できました。 なお、 >0001年1月1日を1としたときの日数 ではなく、 0001年1月1日を「0」としたときの日数 のようです。 日数の計算にはこちらのサイトを利用しました。 https://keisan.casio.jp/exec/system/1177658154
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問