質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
DateTime

多くのプログラミング言語におけるDateTimeオブジェクトは、日付と時間に関する演算と出力を行います。

Matplotlib

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

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

Q&A

解決済

1回答

3954閲覧

matplotlibでx軸を月ごとではなく、年ごとに表示したい。

daisukezr

総合スコア13

DateTime

多くのプログラミング言語におけるDateTimeオブジェクトは、日付と時間に関する演算と出力を行います。

Matplotlib

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

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

0グッド

1クリップ

投稿2021/01/16 13:19

データに格納されている日付は202101のように、年と月がくっついた形になっています。

データの量は2010年の1月から2020年の12月までで、普通にplt.plotをするとxのメモリがつぶれてしまいます。
(グラフ割愛)

そこで、年ごとに表示するよう試しているのですがうまくいきません。どなたか原因わかる方いらっしゃいますか。

*元データの都合上、df['類・品目']が日付が入っている場所です。
##試したこと1

import matplotlib.dates as dates ... df = pd.read_csv(r"C:\Users\name\Downloads\zmi2015s.csv",encoding="SHIFT-JIS",parse_dates=['類・品目']) fig = plt.figure() ax = fig.add_subplot(1, 1, 1) ax.plot(df['cpi'], color='black') ax.set_xlabel('year-month') ax.set_ylabel('cpi') ax.xaxis.set_major_locator(dates.YearLocator(1)) ax.xaxis.set_major_formatter(DateFormatter('%Y-%m'))

###結果1
イメージ説明
なぜか範囲外の1970-01だけが表示される。

##試したこと2
parse_datesが機能してないのかと思い、確実にdatetimeに変換してみる。

new_xticks = [] for index, row in df.iterrows(): row['date'] = datetime(int(row['類・品目'][:4]), int(row['類・品目'][4:]), 1) new_xticks.append(date2num(datetime(int(row['類・品目'][:4]), int(row['類・品目'][4:]), 1))) fig = plt.figure() ax = fig.add_subplot(1, 1, 1) ax.plot(df['date'],df['cpi'], color='black') ax.set_xlabel('year-month') ax.set_ylabel('cpi') ax.xaxis.set_major_locator(ticker.FixedLocator(new_xticks)) ax.xaxis.set_major_formatter(DateFormatter('%Y-%m'))

###結果2
さっきのグラフの1970-01がないまっさらな状態が表示される。

###参考にした記事
https://qiita.com/yoinhu/items/e0039309a47c75dade05

https://teratail.com/questions/140007

上にも書いた通り、年ごと2010, 2011, 2012 ...だけのメモリにしたいです。

お力添えよろしくお願いします・。

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

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

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

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

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

guest

回答1

0

ベストアンサー

「試したこと1」のほうのコードでは
ax.plot()の中でx軸の指定df['類・品目']が漏れています。
これが原因で、x軸の値が0,1,2,...になってしまい、これを日付に変換して、日付の基準日の1970/1/1からが表示されているのだと思います。

投稿2021/01/17 00:46

Amakaze

総合スコア313

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

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

daisukezr

2021/01/17 01:01

回答ありがとうございます。ax.plot(df['類・品目'],df['cpi'], color='black')で試してみましたが同じ結果でした。。
Amakaze

2021/01/17 01:27

返信ありがとうございます。手元で少し確認したのですが、202101のような月までの形はうまく日付に変換されていなさそうですね。parse_datesを指定せずに文字列として読み込んで df['類・品目'] = pd.to_datetime(df['類・品目'] + "01") として、20210101のような日付まで入った形にしてから変換すると、うまくいくかもしれません。
daisukezr

2021/01/17 01:34

うまくいきました。ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問