时间:2021-05-22
我就废话不多说了,还是直接看代码吧!
import pandas as pd# 伪造一些数据fake_data = {'subject':['math', 'english'], 'A': [88, 90], 'B': [70, 80], 'C': [60, 78]}# 宽表test = pd.DataFrame(fake_data, columns=['subject', 'A', 'B', 'C'])test subject A B C0 math 88 70 601 english 90 80 78# 转换为窄表pd.melt(test, id_vars=['subject'])subject variable value0 math A 881 english A 902 math B 703 english B 804 math C 605 english C 78补充知识:pandas从单条目数据集生成宽表
需求
场景
从医院数据库中导出了大量的体检数据,但体检数据表中,每一行代表某人某次体检的某一项体检的结果。目的想将每一个人的每一次体检结果作为一行存储,每一列为体检项。
示例
StuID Type Num 0 111021 Math 89 1 111021 English 93 2 312983 English 91 3 314621 English 82 4 314621 Math 92 5 112341 Math 82目的:转换成如下表格
StuID English Math 0 111021 93 89 1 312983 91 NaN 2 314621 82 92 3 112341 NaN 82方案一
具体代码如下
#将'B'列的类别调整为行。#1num = df[~df.duplicated(subset=['StuID'])].loc[:,'StuID'].to_list()#2result_df = pd.DataFrame({'StuID': np.array(num)},columns=['StuID','English','Math'])#3for i in df.index: t = df.loc[i,'Type'] num = df.loc[i,'StuID'] result_df.loc[result_df['StuID'] == num,[t]] = df.loc[i,'Num']print(result_df)结果
以上这篇pandas使用之宽表变窄表的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
以excel为例,把内容打印到一页上的方法如下: 1、首先点选格式,自动调整列宽。 2、再在打印中,设为窄页边距。 3、如果依旧打印不全,可以将工作表调整
mysql中using的用法为:using()用于两张表的join查询,要求using()指定的列在两个表中均存在,并使用之用于join的条件。示例:复制代码代
设置了宽屏和窄屏可以自由切换的时候,输出宽屏和窄屏的切换按钮。{langswitch_narrow}{langswitch_wide}
设置单元格的行高和列宽,是每个使用软件人员必须学会的,初学者一定得掌握,只有设置好工作表中单元格的行高和列宽,这个工作表看起来才会美观、清晰、有条理。下面一
设置单元格的行高和列宽,是每个使用软件人员必须学会的,初学者一定得掌握,只有设置好工作表中单元格的行高和列宽,这个工作表看起来才会美观、清晰、有条理。下面一起来