按其中一个级别对多索引 pandas 数据框进行分组?

问题描述 投票:0回答:3

是否可以按多索引级别之一对多索引(2 个级别)pandas 数据框进行分组?

我知道的唯一方法是在多重索引上重置索引,然后再次设置索引。我确信有更好的方法可以做到这一点,并且我想知道如何做。

python pandas
3个回答
40
投票

是的,使用

level
方法的
groupby
参数。看看这里。示例:

In [26]: s

first  second  third
bar    doo     one      0.404705
               two      0.577046
baz    bee     one     -1.715002
               two     -1.039268
foo    bop     one     -0.370647
               two     -1.157892
qux    bop     one     -1.344312
               two      0.844885
dtype: float64

In [27]: s.groupby(level=['first','second']).sum()

first  second
bar    doo       0.981751
baz    bee      -2.754270
foo    bop      -1.528539
qux    bop      -0.499427
dtype: float64

4
投票

在 pandas 的最新版本中,您可以按类似于列的多索引级别名称进行分组(即没有

level
关键字),从而允许您同时使用两者。

>>> import pandas as pd
>>> pd.__version__
'1.0.5'
>>> df = pd.DataFrame({
...     'first': ['a', 'a', 'a', 'b', 'b', 'b'],
...     'second': ['x', 'y', 'x', 'z', 'y', 'z'],
...     'column': ['k', 'k', 'l', 'l', 'm', 'n'],
...     'data': [0, 1, 2, 3, 4, 5],
... }).set_index(['first', 'second'])
>>> df.groupby('first').sum()
       data
first      
a         3
b        12
>>> df.groupby(['second', 'column']).sum()
               data
second column      
x      k          0
       l          2
y      k          1
       m          4
z      l          3
       n          5

您指定的列和索引级别名称

groupby
必须是唯一的。 如果您有同名的列和索引级别,则在尝试
ValueError
时您将得到
groupby


1
投票

如果已经有多个可用索引,则可以简单地使用位置号来代替列名:

df = df.groupby(level=[0,1]).size()
© www.soinside.com 2019 - 2024. All rights reserved.