网络编程
位置:首页>> 网络编程>> Python编程>> pandas使用之宽表变窄表的实现

pandas使用之宽表变窄表的实现

作者:爾莎  发布时间:2022-04-21 06:04:02 

标签:pandas,宽表,窄表

我就废话不多说了,还是直接看代码吧!


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
subjectABC
0math887060
1english908078

# 转换为窄表
pd.melt(test, id_vars=['subject'])

subjectvariablevalue
0mathA88
1englishA90
2mathB70
3englishB80
4mathC60
5englishC78

补充知识:pandas从单条目数据集生成宽表

需求

场景

从医院数据库中导出了大量的体检数据,但体检数据表中,每一行代表某人某次体检的某一项体检的结果。目的想将每一个人的每一次体检结果作为一行存储,每一列为体检项。

示例


StuIDTypeNum
0111021Math89
1111021English93
2312983English91
3314621English82
4314621Math92
5112341Math82

目的:转换成如下表格


StuIDEnglishMath
01110219389
131298391NaN
23146218292
3112341NaN82

方案一

pandas使用之宽表变窄表的实现

具体代码如下


#将'B'列的类别调整为行。
#1
num = df[~df.duplicated(subset=['StuID'])].loc[:,'StuID'].to_list()
#2
result_df = pd.DataFrame({'StuID': np.array(num)},columns=['StuID','English','Math'])
#3
for 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使用之宽表变窄表的实现

来源:https://blog.csdn.net/Guo_ya_nan/article/details/82955345

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com