在Pandas数据帧中创建具有分层索引的子集表

时间:2014-07-03 13:46:18

标签: python loops pandas subset multi-index

我想迭代分层索引熊猫数据帧并根据“group1”级别打印子集。

这是我的数据框

df = pd.DataFrame({'group1': ['a','a','a','b','b','b','c','c','d','d','d','d','d'],
                        'group2': ['c','c','d','d','d','e','f','f','e','d','d','d','e'],
                        'value1': [1.1,2,3,4,5,6,7,8,9,1,2,3,4],
                        'value2': [7.1,8,9,10,11,12,43,12,34,5,6,2,3]})

df = df.set_index(['group1', 'group2'])

这就是它的样子:

               value1  value2
group1 group2                
a      c          1.1     7.1
a      c          2.0     8.0
a      d          3.0     9.0
b      d          4.0    10.0
b      d          5.0    11.0
b      e          6.0    12.0
c      f          7.0    43.0
d      f          8.0    12.0
d      e          9.0    34.0
d      d          1.0     5.0
d      d          2.0     6.0
d      d          3.0     2.0
d      e          4.0     3.0

我可以成功打印基于group1的SINGLE子集,如下所示:

print df.xs('a', level=0)  

        value1  value2
group2                
c          1.1     7.1
c          2.0     8.0
d          3.0     9.0

但是如何将其置于循环中以打印“group1”中每组元素的子集?

我失败的尝试:

for group1, group2 in df.index: 
    print df.xs(group1, level=0)

这为每个索引打印了一个子集,而不是将它们分组在一起(希望这是有意义的)。

2 个答案:

答案 0 :(得分:2)

在索引上使用get_level_values只返回该级别的索引值,另外调用unique,因为返回的是每个次级行的重复索引值。

In [35]:

for gp in df.index.get_level_values(0).unique():
    print (df.xs(gp, level=0))
        value1  value2
group2                
c          1.1     7.1
c          2.0     8.0
d          3.0     9.0

[3 rows x 2 columns]
        value1  value2
group2                
d            4      10
d            5      11
e            6      12

[3 rows x 2 columns]
        value1  value2
group2                
f            7      43
f            8      12

[2 rows x 2 columns]
        value1  value2
group2                
e            9      34
d            1       5
d            2       6
d            3       2
e            4       3

[5 rows x 2 columns]

答案 1 :(得分:1)

这是groupby的用途(迭代给出你的组名,组):

In [13]: for g, grp in df.groupby(level='group1'):
    print grp
   ....:     
               value1  value2
group1 group2                
a      c          1.1     7.1
       c          2.0     8.0
       d          3.0     9.0
               value1  value2
group1 group2                
b      d            4      10
       d            5      11
       e            6      12
               value1  value2
group1 group2                
c      f            7      43
       f            8      12
               value1  value2
group1 group2                
d      e            9      34
       d            1       5
       d            2       6
       d            3       2
       e            4       3

大多数时候你真的想用它做点什么,例如

df.groupby(level='group1').sum()