最佳答案
给定一个具有不同分类变量的数据框架,如何用百分比而不是频率返回交叉表格?
df = pd.DataFrame({'A' : ['one', 'one', 'two', 'three'] * 6,
'B' : ['A', 'B', 'C'] * 8,
'C' : ['foo', 'foo', 'foo', 'bar', 'bar', 'bar'] * 4,
'D' : np.random.randn(24),
'E' : np.random.randn(24)})
pd.crosstab(df.A,df.B)
B A B C
A
one 4 4 4
three 2 2 2
two 2 2 2
在交叉表中使用边距选项来计算行和列的总数可以让我们足够接近地认为使用 aggfunc 或 groupby 应该是可能的,但是我那贫乏的大脑无法想清楚。
B A B C
A
one .33 .33 .33
three .33 .33 .33
two .33 .33 .33