1

私は次の問題を抱えています-計算の出力は私に2つのatomic_numberフィールドを与えます:

In [7]: partition_functions
Out[7]: 
atomic_number  ion_number
14             0             11.291802
               1              5.866805
               2              1.004422
               3              2.000202
26             0             59.650557
               1             66.895978
               2             28.186253
               3              6.569105

In [8]: def group_func(group):
    return group[1:]/group[:-1].values
   ...: 

In [9]: partition_functions.groupby(level='atomic_number').apply(group_func)
Out[9]: 
atomic_number  atomic_number  ion_number
14             14             1             0.519563
                              2             0.171204
                              3             1.991397
26             26             1             1.121464
                              2             0.421345
                              3             0.233061

新しいシリーズを作るなど、いくつか試してみましたが、何も機能しませんでした。

助けてくれてありがとう

4

1 に答える 1

2

どうですか:

def group_func(group):
    return (group / group.shift(1))

partition_functions.groupby(level='atomic_number').apply(group_func).dropna()

その結果:

                            values
atomic_number ion_number          
14            1           0.519563
              2           0.171204
              3           1.991396
26            1           1.121464
              2           0.421345
              3           0.233061
于 2012-12-18T08:53:51.707 に答える