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

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

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

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

NumPy

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

Python

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

pandas

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

Q&A

解決済

1回答

1597閲覧

.agg()集計後の値から散布図を作成したい

8960

総合スコア108

Matplotlib

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

NumPy

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

Python

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

pandas

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

0グッド

0クリップ

投稿2021/11/27 01:04

前提・実現したいこと

以下のコードにおいて、x軸に"Speed"の90th値、y軸に"Angle"のmean値の散布図を作成したいです(凡例は"Player")。
ax= dfx.loc[dfx.index[:-1]].plot.scatter()
↑のscatter()で、x,y値を設定しなけばならないと思うのですが、.agg()で集計されて新しくできたカラムの指定の方法がわかりません。
そもそもplot.scatter()←この書き方があっているかどうか...。

ご教授の程、よろしくお願い致します。
初心者にもわかりやすいよう、若干の説明も加えていただけると幸いです。

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

TypeError: scatter() missing 2 required positional arguments: 'x' and 'y'

該当のソースコード

python

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

試したこと

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

python3.9.4,vscode

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

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

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

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

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

guest

回答1

0

ベストアンサー

python

1#plt.figure(figsize=(15,10)) 2fig, ax = plt.subplots(figsize=(15,10)) 3 4dfx[:-1].plot.scatter(x=('Speed', 'mean'), y=('Angle', 'mean'), ax=ax) 5 6ax.set_xlabel("Speed") 7ax.set_ylabel("Angle") 8ax.set_ylim(80,130) 9ax.set_ylim(-20,20)

scatter

投稿2021/11/27 03:01

編集2021/11/27 04:10
melian

総合スコア20655

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

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

8960

2021/11/27 03:56

.plot.scatter(x=('Speed', '90th'), y=('Angle', 'mean') ↑このように表記するのですね。ありがとうございます! もう一つグラフに関する質問を投稿してますので、ご回答いただけると幸いです。
melian

2021/11/27 04:09

了解です。それから、dfx.loc[dfx.index[:-1]] という書き方は df[:-1] で十分でした。この回答は直しますが、過去の回答はそのままにしておきますので、そちらで作成したプログラムでは適宜修正しておいて下さい。
8960

2021/11/27 04:15

承知しました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問