我有类似这样大熊猫师(.div)与多指标
df = pd.DataFrame(np.random.randint(2, 10, size = (5, 2)))
df.index = pd.MultiIndex.from_tuples([(1, 'A'), (2, 'A'), (4, 'B'),
(5, 'B'), (8, 'B')])
df.index.names = ['foo', 'bar']
df.columns = ['count1', 'count2']
df
一些东西,得到:
count1 count2
foo bar
1 A 6 7
2 A 2 9
4 B 6 7
5 B 4 6
8 B 5 6
我也有通过同样从某处else- -obtained总数的列表'富' 指数:
totals = pd.DataFrame([2., 1., 1., 1., 10.])
totals.index = [1, 2, 4, 5, 8]
totals.index.names = ['foo']
totals
其给出:
0
foo
1 2
2 1
4 1
5 1
8 10
我怎么能由是在总计 foo的数字除以DF(COUNT1和COUNT2)的所有列? (因此,我需要通过'富'数字匹配)
我检查了this question,看起来它应该做的伎俩,但我无法弄清楚。
我试图
df.div(totals, axis = 0)
和改变DIV的水平选项,但没有成功。
与往常一样,非常感谢您的时间
不幸的是,我没有时间去成为一个更详细的解答。以下链接是否可以帮助你? http://stackoverflow.com/questions/13940753/aligning-dataframes-with-same-columns-different-index-levels –
这是一个重复的:http://stackoverflow.com/questions/19501510/divide-entire- pandas-multiindex-dataframe-by-dataframe-variable – Jeff
嗨,我检查了这些答案并尝试使用选项level = 0或level ='foo',但它不起作用。 Roman Pekar的回答如下,但我不明白为什么。 – cd98