首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Pivot Pivot创建映射表

Pivot Pivot创建映射表
EN

Stack Overflow用户
提问于 2020-07-20 03:51:51
回答 2查看 35关注 0票数 1

我有以下格式的数据,其中Column_1中的值映射到Map_1、Map_2或Map_3。但是,数据不是具有映射表,而是以下面的格式存在,其中1标记Column_1中的哪个值映射到哪个映射值

代码语言:javascript
复制
Column_1 Map_1 Map_2 Map_3
 A         0     1    0 
 B         1     0    0
 C         1     0    0
 D         0     0    1

我想将其转换为以下格式:

代码语言:javascript
复制
A   Map_2
B   Map_1
C   Map_1
D   Map_3
代码语言:javascript
复制
EN

回答 2

Stack Overflow用户

发布于 2020-07-20 03:58:24

假设Column_1是您的索引,请尝试使用pd.DataFrame.dot

代码语言:javascript
复制
df.dot(df.columns)

如果Column_1不是您的索引,请尝试:

代码语言:javascript
复制
df[df.colmuns[1:]].dot(df.columns)

输出:

代码语言:javascript
复制
A    Map_2
B    Map_1
C    Map_1
D    Map_3
dtype: object
票数 0
EN

Stack Overflow用户

发布于 2020-07-20 03:59:06

熊猫的idxmax前来营救。它返回最大值的列,在您的情况下就足够了:

代码语言:javascript
复制
import pandas as pd

df = pd.DataFrame({"Bird":[1,0,1,0], "Snake":[0,0,0,1], "Dog":[0,1,0,0]}) 
df.idxmax(1)

DataFrame:

代码语言:javascript
复制
   Bird Snake Dog
0   1   0   0
1   0   0   1
2   1   0   0
3   0   1   0

代码输出:

代码语言:javascript
复制
1      Dog
2     Bird
3    Snake
dtype: object

对于您的案例:

代码语言:javascript
复制
df.loc[:, ["Map_1", "Map_2", "Map_3"]].idxmax(1)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62984952

复制
相关文章

相似问题

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