1. ホーム
  2. python-3.x

パンダはグループ内の行に番号をつける。

2023-09-29 05:40:15

質問

次のようなデータフレームがあるとする。

import pandas as pd
import numpy as np
df=pd.DataFrame({'A':['A','A','A','B','B','B'],
                'B':['a','a','b','a','a','a'],
                })
df

    A   B
0   A   a 
1   A   a 
2   A   b 
3   B   a 
4   B   a 
5   B   a

このようにA列、B列の各グループ内の行に番号を振る列「C」を作りたいと思います。

    A   B   C
0   A   a   1
1   A   a   2
2   A   b   1
3   B   a   1
4   B   a   2
5   B   a   3

ここまで試したところ

df['C']=df.groupby(['A','B'])['B'].transform('rank')

...が、うまくいきません!

どのように解決するのですか?

使用方法 groupby/cumcount :

In [25]: df['C'] = df.groupby(['A','B']).cumcount()+1; df
Out[25]: 
   A  B  C
0  A  a  1
1  A  a  2
2  A  b  1
3  B  a  1
4  B  a  2
5  B  a  3