首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过将字符串值作为列标题将列拆分为多个列?

如何通过将字符串值作为列标题将列拆分为多个列?
EN

Stack Overflow用户
提问于 2022-11-04 10:03:44
回答 1查看 59关注 0票数 1

这是我的数据集:

代码语言:javascript
复制
| Name     | Dept     | Project area/areas interested     | 
| -------- | -------- |-----------------------------------|
| Joe      | Biotech  | Cell culture//Bioinfo//Immunology |
| Ann      | Biotech  | Cell culture                      |
| Ben      | Math     | Trigonometry//Algebra             |
| Keren    | Biotech  | Microbio                          |
| Alice    | Physics  | Optics                            |

这就是我想要的结果:

代码语言:javascript
复制
| Name     | Dept     |Cell culture|Bioinfo|Immunology|Trigonometry|Algebra|Microbio|Optics|
| -------- | -------- |------------|-------|----------|------------|-------|--------|------|
| Joe      | Biotech  |     1      |   1   |    1     |      0     |   0   |   0    | 0    |
| Ann      | Biotech  |     1      |   0   |    1     |      0     |   0   |   0    | 0    |   
| Ben      | Math     |     0      |   0   |    0     |      1     |   1   |   0    | 0    |
| Keren    | Biotech  |     0      |   0   |    0     |      0     |   0   |   1    | 0    |
| Alice    | Physics  |     0      |   0   |    0     |      0     |   0   |   0    | 1    |

我不仅必须根据行将最后一列拆分为不同的列,而且还必须重新划分由"//“分隔的某些列值。而dataframe中的值必须替换为1或0 (int)。我被困在这件事上已经有一段时间了(-_;)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-04 10:23:53

您可以将pandas.concat与pandas.get_dummies结合使用,如下所示:

代码语言:javascript
复制
pd.concat([df[["Name", "Dept"]], df["Project area/areas interested"].str.get_dummies(sep='//')], axis=1)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74315235

复制
相关文章

相似问题

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