分组后合并

5 投票
1 回答
5193 浏览
提问于 2025-04-18 10:57

我在使用pd.merge之后遇到了麻烦。下面是我的一个假设例子:

import pandas as pd
from pandas import DataFrame
import numpy as np

df1 = DataFrame({'key': [1,1,2,2,3,3],
                 'var11': np.random.randn(6),
                 'var12': np.random.randn(6)})
df2 = DataFrame({'key': [1,2,3],
                 'var21': np.random.randn(3),
                 'var22': np.random.randn(3)})

#group var11 in df1 by key
grouped = df1['var11'].groupby(df1['key'])

# calculate the mean of var11 by key
grouped = grouped.mean()
print grouped
key
1      1.399430
2      0.568216
3     -0.612843
dtype: float64

print grouped.index
Int64Index([1, 2, 3], dtype='int64')

print df2
   key     var21     var22
0    1 -0.381078  0.224325
1    2  0.836719 -0.565498
2    3  0.323412 -1.616901

df2 = pd.merge(df2, grouped, left_on = 'key', right_index = True)

在这个时候,我遇到了IndexError: list index out of range的错误。

使用groupby的时候,分组变量(在这个例子中是'key')会变成结果系列的索引,所以我需要指定'right_index = True'。我试过其他的写法,但都没有成功。有没有什么建议?

1 个回答

5

我觉得你只需要这样做:

In [140]:

df2 = pd.merge(df2,
               pd.DataFrame(grouped, columns=['mean']),
               left_on='key', 
               right_index=True)
print df2
   key     var21     var22      mean
0    1  0.324476  0.701254  0.400313
1    2 -1.270500  0.055383 -0.293691
2    3  0.804864  0.566747  0.628787

[3 rows x 4 columns]

之所以不成功,是因为 grouped 是一个 Series,而不是一个 DataFrame

撰写回答