3 回答
TA贡献1752条经验 获得超4个赞
您可以使用以下get_group方法:
In [21]: gb.get_group('foo')
Out[21]:
A B C
0 foo 1.624345 5
2 foo -0.528172 11
4 foo 0.865408 14
注意:这不需要为每个组创建一个中间字典/每个子数据帧的副本,因此,与使用创建天真的字典相比,它的内存效率更高dict(iter(gb))。这是因为它使用了groupby对象中已经可用的数据结构。
您可以使用groupby切片选择不同的列:
In [22]: gb[["A", "B"]].get_group("foo")
Out[22]:
A B
0 foo 1.624345
2 foo -0.528172
4 foo 0.865408
In [23]: gb["C"].get_group("foo")
Out[23]:
0 5
2 11
4 14
Name: C, dtype: int64
TA贡献1852条经验 获得超1个赞
Python for Data Analysis中的Wes McKinney(熊猫的作者)提供了以下方法:
groups = dict(list(gb))
它返回一个字典,其键是您的组标签,其值是DataFrames,即
groups['foo']
将产生您想要的东西:
A B C
0 foo 1.624345 5
2 foo -0.528172 11
4 foo 0.865408 14
添加回答
举报