ホームページ >バックエンド開発 >Python チュートリアル >Pandas GroupBy.agg() を使用して複数の集計関数を同じ列に適用するにはどうすればよいですか?

Pandas GroupBy.agg() を使用して複数の集計関数を同じ列に適用するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-01 00:22:09269ブラウズ

How Can I Apply Multiple Aggregation Functions to the Same Column Using Pandas GroupBy.agg()?

pandas GroupBy.agg() を使用した同じ列の複数の集計

問題:

複数の集計関数(f1、f2)を同じ列に適用するにはどうすればよいですか? (「戻り値」) agg() を複数回呼び出さずに GroupBy.agg() を使用するパンダ DataFrame 内で?

直感:

構文例:

df.groupby("dummy").agg({"returns": [f1, f2]})

解決策:

2022 年 6 月 20 日現在、次の構文が受け入れられています:

df.groupby('dummy').agg(
    Mean=('returns', np.mean),
    Sum=('returns', np.sum),
)

この構文では、タプルを使用して (列、関数) ペアを指定します。 aggregation.

これまでのソリューション:

以前のバージョンの pandas では、次のソリューションのいずれかを使用できました:

  • のリスト関数:

    df.groupby("dummy").agg({"returns": [np.mean, np.sum]})
  • 関数リストを含む辞書:

    df.groupby('dummy').agg({'returns':
                                 {'Mean': np.mean, 'Sum': np.sum}})

これらの以前のソリューションは次のとおりです。まだ有効ですが、タプルを使用する最初のオプションがベスト プラクティスとみなされます。

以上がPandas GroupBy.agg() を使用して複数の集計関数を同じ列に適用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。