我有一个DataFrame具有以下结构的Multindex :
0 1 2 ref
A B
21 45 0.01 0.56 0.23 0.02
22 45 0.30 0.88 0.53 0.87
23 46 0.45 0.23 0.90 0.23
Run Code Online (Sandbox Code Playgroud)
我想用它做的是:
从列[0:2]中选择与"ref"列最接近的值,所以预期的结果是:
closest
A B
21 45 0.01
22 45 0.88
23 46 0.23
Run Code Online (Sandbox Code Playgroud)
重建你的DataFrame:
In [1]: index = MultiIndex.from_tuples(zip([21,22,23],[45,45,46]), names=['A', 'B'])
In [2]: df = DataFrame({0:[0.01, 0.30, 0.45],
1:[0.56, 0.88, 0.23],
2:[0.23, 0.53, 0.90],
'ref': [0.02, 0.87, 0.23]}, index=index)
In [3]: df
Out[3]:
0 1 2 ref
A B
21 45 0.01 0.56 0.23 0.02
22 45 0.30 0.88 0.53 0.87
23 46 0.45 0.23 0.90 0.23
Run Code Online (Sandbox Code Playgroud)
我首先获得 columns 的绝对距离0,1并且2来自ref:
In [4]: dist = df[[0,1,2]].sub(df['ref'], axis=0).apply(np.abs)
In [5]: dist
Out[5]:
0 1 2
A B
21 45 0.01 0.54 0.21
22 45 0.57 0.01 0.34
23 46 0.22 0.00 0.67
Run Code Online (Sandbox Code Playgroud)
现在dist您可以使用以下命令按行确定具有最小值的列DataFrame.idxmin:
In [5]: idx = dist.idxmin(axis=1)
In [5]: idx
Out[5]:
A B
21 45 0
22 45 1
23 46 1
Run Code Online (Sandbox Code Playgroud)
现在要生成新的closest,那么您只需使用idxto 索引df:
In [6]: df['closest'] = idx.index.map(lambda x: df.ix[x][idx.ix[x]])
In [7]: df
Out[7]:
0 1 2 ref closest
A B
21 45 0.01 0.56 0.23 0.02 0.01
22 45 0.30 0.88 0.53 0.87 0.88
23 46 0.45 0.23 0.90 0.23 0.23
Run Code Online (Sandbox Code Playgroud)
对于最后一步,可能有一种更优雅的方法来做到这一点,但我对 Pandas 相对较新,这是我现在能想到的最好的方法。
| 归档时间: |
|
| 查看次数: |
2373 次 |
| 最近记录: |