Option 1
pd.get_dummies + groupby+sum
v = pd.get_dummies(df.set_index('col0'))
v.columns = pd.MultiIndex.from_tuples(
list(map(tuple, v.columns.str.split('_')))
)
v.sum(level=0)
col1 col2
no yes no yes
col0
A 1 1 2 0
B 0 2 1 1
Option 2
stack + get_dummies+unstack
(df.set_index('col0')
.stack()
.str.get_dummies()
.sum(level=[0,1])
.unstack(-1)
.swaplevel(0, 1, axis=1)
.sort_index(level=0, axis=1)
)
col1 col2
no yes no yes
col0
A 1 1 2 0
B 0 2 1 1
Option 3
crosstab + concatby @Wen
i = pd.crosstab(df.col0, df.col1.astype('category'))
j = pd.crosstab(df.col0, df.col2.astype('category'))
pd.concat([i, j], axis=1, keys=['col1','col2'])
col1 col2
col1 no yes no yes
col0
A 1 1 2 0
B 0 2 1 1
source
share