为 pandas MultiIndex设置一个级别 [英] Prepend a level to a pandas MultiIndex
本文介绍了为 pandas MultiIndex设置一个级别的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在分组后,我创建了一个具有MultiIndex的DataFrame:
I have a DataFrame with a MultiIndex created after some grouping:
import numpy as np
import pandas as p
from numpy.random import randn
df = p.DataFrame({
'A' : ['a1', 'a1', 'a2', 'a3']
, 'B' : ['b1', 'b2', 'b3', 'b4']
, 'Vals' : randn(4)
}).groupby(['A', 'B']).sum()
df
Output> Vals
Output> A B
Output> a1 b1 -1.632460
Output> b2 0.596027
Output> a2 b3 -0.619130
Output> a3 b4 -0.002009
如何在MultiIndex的前面添加一个级别,以便将其转换为类似的内容:
How do I prepend a level to the MultiIndex so that I turn it into something like:
Output> Vals
Output> FirstLevel A B
Output> Foo a1 b1 -1.632460
Output> b2 0.596027
Output> a2 b3 -0.619130
Output> a3 b4 -0.002009
推荐答案
使用pandas.concat()
在同一行中完成此操作的一种好方法:
A nice way to do this in one line using pandas.concat()
:
import pandas as pd
pd.concat([df], keys=['Foo'], names=['Firstlevel'])
这可以推广到许多数据框架,请参见文档.
This can be generalized to many data frames, see the docs.
这篇关于为 pandas MultiIndex设置一个级别的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文