首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何将一维DataFrame扩展为具有布尔值的二维DataFrame?

如何将一维DataFrame扩展为具有布尔值的二维DataFrame?
EN

Stack Overflow用户
提问于 2016-12-14 18:12:10
回答 1查看 146关注 0票数 1
代码语言:javascript
运行
复制
>>> df = pd.DataFrame(data = ['a','b','b','c'],index=['day1','day1','day2','day2'],columns=['name'])

     name
day1    a
day1    b
day2    b
day2    c

如何将df转换为具有布尔值的二维DataFrame,如

代码语言:javascript
运行
复制
      a  b  c
day1  1  1  0
day2  0  1  1
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-14 18:13:26

1) (较慢的方法)--使用crosstab计算频数表:

代码语言:javascript
运行
复制
pd.crosstab(df.index, df['name'], rownames=[None]).rename_axis(None, 1)

2) (更快的方法)--在索引轴上执行Groupby,并通过用0填充缺失的值来采取相应的value_counts + unstack

代码语言:javascript
运行
复制
df.groupby(level=0)['name'].value_counts().unstack(fill_value=0).rename_axis(None, 1)

在这两种情况下产生的产出:

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41149324

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档