Если у меня есть Dataframe, и я бы хотел в начале вставить итоговый столбец, я могу запустить
df.insert(0, 'Average', df.mean(axis='columns'))
Скажем, у меня есть мультииндексированный фрейм данных в форме
df = pd.DataFrame()
for l1 in ('a', 'b'):
for l2 in ('one', 'two'):
df[l1, l2] = np.random.random(size=5)
df.columns = pd.MultiIndex.from_tuples(df.columns, names=['L1', 'L2'])
L1 a b
L2 one two one two
0 0.585409 0.563870 0.535770 0.868020
1 0.404546 0.102884 0.254945 0.362751
2 0.475362 0.601632 0.476761 0.665126
3 0.926288 0.615655 0.257977 0.668778
4 0.509069 0.706685 0.355842 0.891862
Как мне добавить среднее значение всех столбцов one
и всех столбцов two
к первым двум столбцам этого DataFrame и назвать его 'Average'
?
РЕДАКТИРОВАТЬ: Ожидаемый результат будет df.mean(level=1, axis=1)
но вставляется в первые два столбца кадра с меткой L1 'Average'
.Я надеялся, что будет работать следующее:
df.insert(0, 'Average', df.mean(level=1, axis=1))