文科生自学Python-pandas交叉透视表降维变换
wptr33 2025-06-09 00:43 6 浏览
--心有猛虎,细嗅蔷薇,学习编程成就更好的自己--
Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可解决工作和学习中碰到的棘手问题。(本人外语专业毕业,机缘巧合爱上编程,自学道路曲曲折折,痛并快乐!)在这里总结一下自学Python遇到的难点和重点,分享码过的代码和要点总结,希望能够给初学者一点启示和鼓励,同时愿意结交更多大神交流有助提升自己的水平。
平时在做数据处理和分析时经常使用pandas进行各种透视操作(pivot_table),而透视中最常见的是进行两个维度交叉查询,此时得到的透视结果集往往是二维表带多级标题,如何把二维表变换成为一维表呢?今天就针对这个问题展开展示和讲解,接下来看看实际案例吧:
原始数据如下:
该数据源主要包括日期,产品名称和销售收入,一般通过交叉透视查询可以得到不同产品在指定日期范围内的销售收入情况,但形成的结果往往是多维表并带多层标题,如何降维成一维表方便满足其他需求呢(例如生成热力图)?
下面来讲讲如何实现吧:
读取和查看数据基本情况:
添加必要的新字段方便后续处理:
通过pivot方法做交叉透视查询(产品和日期维度交叉)结果如下:
看到该表的产品上方是日期&星期标题,而日期&星期具体数据上方则是收入标题,如何消除日期&星期标题和收入标题呢?这样得到的就是一维数据表了。
关键步骤1-重置该透视表索引:
可以看到产品来到了数据帧里面,同时一个新的索引出现了,该索引是关键哦!!!!方便后续拼接数据。
关键步骤2-抽取日期对应的数据内容,数据索引还是那个新索引:
注意:这里得到的还是DataFrame即数据帧,这个部分就是透视表中的核心数值内容,但缺少产品名称。
关键步骤3-抽取产品名数据,数据索引还是那个共同的新索引:
关键步骤4-通过concat方法横向拼接两个数据得到结果:
最后把产品名称改为索引列如下:
是不是感觉到索引列十分有用和神奇哇!!
该一维结果集方便阅读同时方便其他处理,例如数据可视化(热力图)如下:
总结处理的全部过程,写成一个自定义函数来完成这个需求:
代码汇总如下:
#import seaborn to draw heatmap
import plotly.graph_objects as go
import matplotlib.pyplot as plt
import plotly_express as px
import seaborn as sns
import pandas as pd
import numpy as np
import datetime
import os
#Set work path
def Set_Work_Path(x):
try:
os.chdir(x) #Set work file path
route = os.getcwd()
print(route) #print the changed path
return route
except Exception:
print("No Result")
work_path = r"E:\DATA\20211002"
Set_Work_Path(work_path)
#读取和检查数据
data = pd.read_excel("DATA-Heatmap.xlsx",header=0,sheet_name="DATA",engine="openpyxl")
display(data.head())
display(data.dtypes)
#构造新的字段方便后续分析
data["Weekday"] = data["Date"].dt.strftime("%a")
data["Date&Weekday"] = data["Date"].astype(str) +"-"+ data["Weekday"].astype(str)
display(data.head())
#通过pivot方法获取透视结果,纵轴显示产品而横轴显示日期和星期
pivot = pd.pivot_table(data,index=["Product"],columns=["Date&Weekday"],values=["Revenue"],aggfunc={"Revenue":np.sum},fill_value=0)
display(pivot)
#通过重置索引方便后续拼接数据
pivot.reset_index(level=0,inplace=True)
display(pivot)
#获取日期星期对应的数据和对应索引
target_content = pivot["Revenue"].astype(int)
display(target_content)
display(type(target_content))
#获取产品对应的数据和对应索引
target_column = pivot["Product"]
display(target_column)
display(type(target_column))
#把两个数据通过索引横向拼接在一起形成一维数据
target_data = pd.concat([target_column, target_content],axis=1) #concat two Dataframes with index
display(target_data)
#将产品重置为索引列
target_data.set_index("Product",inplace=True)
display(target_data)
#https://seaborn.pydata.org/tutorial/color_palettes.html#tools-for-choosing-color-palettes
def Get_Heatmap(X):
f, ax = plt.subplots(figsize=(20,5))
fig = sns.heatmap(X,annot=True,fmt="d",linewidths=0.5,cmap="RdBu_r") #Blues crest
nowTime = datetime.datetime.now()
Update_Time = nowTime.strftime('%Y-%m-%d-%H-%M')
data_out_title = "Product-Revenue-Heatmap-"+Update_Time
fig.set_title(label=data_out_title)
fig.xaxis.set_ticks_position("top")
return plt.show()
Get_Heatmap(target_data)
#定义一个降维函数
def Get_Pivot_To_df(X):
try:
pivot = pd.pivot_table(X,index=["Product"],columns=["Date&Weekday"],values=["Revenue"],aggfunc={"Revenue":np.sum},fill_value=0)
pivot.reset_index(level=0,inplace=True)
target_content = pivot["Revenue"].astype(int)
target_column = pivot["Product"]
target_data = pd.concat([target_column, target_content],axis=1) #concat two Dataframes with index
target_data.set_index("Product",inplace=True)
return target_data
except Exception:
pass
target = Get_Pivot_To_df(data)
display(target)
解决这个问题的关键就是重置索引后得到一个共同的新索引,新索引利用concat方法进行横向拼接,大家是不是也看明白了,如果有兴趣那就赶紧动手试一下哇!!!解决这个问题可能还有更简洁和优雅的办法,如果其他小伙伴恰好知道和熟悉别的途径,欢迎与本人分享和讨论。
END
我为人人,人人为我!!欢迎大家关注,点赞和转发!!!
~~人生不是赛场,梦想不容退场~~不断努力学习蜕变出一个更好的自己,不断分享学习路上的收获和感悟帮助他人成就自己!!!
相关推荐
- flarum安装使用教程(flm安装教程安卓)
-
Flarum是一款现代化的、简洁美观的论坛软件,以下是关于它的环境安装:安装搭建基础环境:...
- 从abc起步学做网站(4)(从abc开始学英语用什么软件)
-
上一次我们做了一个大多数网站使用的模板,带有顶部、左侧导航、右侧主内容、底部等板块。现在我们把它逐步扩展成一个论坛。一个论坛的基本功能有注册,登陆,发帖,回帖,看帖,删帖等,我们一步步来做。首先大多数...
- 了解webshell变形的一些思路(webxshell)
-
请遵守法律法规,文章旨在提高安全软件的应变策略,严禁非法使用,后果自负。前言在攻防场景下,黑客常常在找到某个上传接口,第一步肯定是先测试后缀是否有限制,第二步则是测试上传的文件是否能解析,最后便确认即...
- MySQL8安装 八: 使用phpMyadmin客户端
-
MySQL8安装一:源码安装...
- PHP基本的语法、注释:让你的代码充满神秘色彩
-
PHP魔法咒语:让你的代码充满神秘色彩(带你进入PHP的魔法世界)一、笔记:基本的PHP语法PHP是一种超级强大的脚本语言,专为Web开发而设计。要想成为真正的PHP魔法师,首先需要掌握一些基本的语法...
- PHP——bc函数及其应用详解(php bcmul)
-
bcadd——两个任意精度数字的加法计算(PHP4,PHP5,PHP7,PHP8)...
- 从零学习php之php语法——课程1(php零基础自学)
-
以后将会每天更新一篇电脑编程教程有需要的朋友记得订阅转发哟怎么学习php?对于想学php还没入门的朋友很多都在纠结怎么开始第一步。我很了解php初学者的心理,因为我也是从那个阶段过来的,也是自学。那...
- 全新版Jetpack进阶提升,系统性落地短视频App|超清完结无秘
-
全新版Jetpack进阶提升,系统性落地短视频App|超清完结无秘来百度APP畅享高清图片...
- Reactive系统的反压(什么是反压)
-
原文BackpressureinReactiveSystemshttps://foojay.io/today/backpressure-in-reactive-systems/?spm=ata...
- Kotlin设计模式:Flyweight(享元)模式
-
享元模式的目的...
- 如何使用 Kotlin 在 Android 应用程序中使用 DataStore 首选项
-
在本教程中,我将向您展示如何使用数据存储首选项在Android应用程序中本地保存数据,而不是使用共享首选项的旧方法。我看到很多人不知道如何使用DataStore,他们认为这太难了,所以在这篇文章...
- Spring Native 中文文档(springdatajpa中文文档)
-
https://docs.spring.io/spring-native/docs/current/reference/htmlsingle/#getting-started-buildpacks...
- 详解Android官推Kotlin-First的图片加载库
-
前言Coil是一个非常年轻的图片加载库,在2020年10月22日才发布了1.0.0版本,但却受到了Android官方的推广,在AndroidDevelopersBackst...
- Spring Boot通过@EnableCaching注解开启全局服务缓存功能!
-
Caching缓存缓存在现代应用中无处不在,它为服务的高可用提供了很大的帮助。Spring框架提供了对缓存的支持。SpringBoot通过@EnableCaching注解开启全局服务缓存功能。对于某...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)