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

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

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

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

Python

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

Q&A

解決済

2回答

530閲覧

.agg()で集計した特定の値の棒グラフを作成したい

8960

総合スコア108

Matplotlib

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

Python

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

0グッド

0クリップ

投稿2021/11/25 12:14

前提・実現したいこと

以下のコードで.groupby().agg()で集計した"Speed"の"percentile(90)"に関して、"Player"がx軸、"percentile(90)"がy軸の棒グラフを作成したいです。

拙い説明ですが、ご教授の程よろしくお願いします。

発生している問題・エラーメッセージ

該当のソースコード

python

1import pandas as pd 2import numpy as np 3pd.options.display.float_format="{:.1f}".format 4start,end = "2021/4/1","2021/4/30" 5dates = pd.date_range(start=start,end=end,freq="D") 6players = [f"Player{i}"for i in range(1,6)] 7 8N = 200 9dates = np.random.choice(dates,size=N) 10dates.sort() 11players=np.random.choice(players,size=N) 12 13df = pd.DataFrame({ 14 "Date": dates, 15 "Player": players, 16 "Speed": np.random.sample(N) * 100.0, 17 "Angle": np.random.sample(N) * 40.0 - 20.0, 18 "Efficiency": np.random.sample(N) * 100.0, 19}) 20 21def percentile(n): 22 def percentile_(x): 23 return np.percentile(x, n) 24 percentile_.__name__ = '%sth' % n 25 return percentile_ 26 27def AA416(angle): 28 return 100*angle[(angle>=4.0)&(angle<16.0)].count()/angle.count() 29 30dfx = df.groupby("Player").agg({ 31 "Player":"count", 32 "Speed":[np.mean,percentile(90),np.max,np.std], 33 "Angle":[np.mean,np.std,AA416], 34 "Efficiency":[np.mean], 35}) 36dfx.loc['Average', :] = dfx.mean()

試したこと

.agg()で集計した特定の値(ここでいう"percentile(90)")に関して、という限定の方法がわかりません。

補足情報(FW/ツールのバージョンなど)

python3.9.4,vscode

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

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

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

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

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

guest

回答2

0

ベストアンサー

軸ラベルやタイトルは適当に付けて下さい。

python

1from matplotlib import pyplot as plt 2 3dfx[('Speed', '90th')].plot.bar() 4plt.show()

イメージ説明

投稿2021/11/25 13:05

melian

総合スコア19805

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

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

0

  • .agg()で集計した特定の値(ここでいう"percentile(90)")に関して、という限定の方法がわかりません。

multiindexですので以下のようにします。

python

1>>> print(dfx) 2 Player Speed Angle Efficiency 3 count mean 90th amax std mean std AA416 mean 4Player 5Player1 32.0 45.7 83.6 93.3 27.8 4.1 11.7 25.0 45.0 6Player2 49.0 55.1 94.0 97.9 31.8 0.9 10.9 34.7 51.6 7Player3 38.0 50.4 82.5 90.0 27.0 1.0 10.4 39.5 52.9 8Player4 30.0 53.2 91.3 99.7 27.3 -2.0 13.6 30.0 54.3 9Player5 51.0 52.4 93.0 99.3 31.2 1.3 10.9 31.4 54.9 10Average 40.0 51.4 88.9 96.0 29.0 1.0 11.5 32.1 51.7 11>>> print(dfx[('Speed', '90th')]) 12Player 13Player1 83.6 14Player2 94.0 15Player3 82.5 16Player4 91.3 17Player5 93.0 18Average 88.9 19Name: (Speed, 90th), dtype: float64

投稿2021/11/25 12:27

ppaul

総合スコア24666

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問