excel数据处理需求,透视表无法解决?用Python吧
off999 2024-09-16 00:40 19 浏览 0 评论
请关注本号,后续会有更多相关教程。转发本文并私信我"python",即可获得按水平领域分类好的Python资料
系列文章
前言
本系列前2篇已经稍微展示了 python 在数据处理方面的强大能力,这主要得益于 pandas 包的各种灵活处理方式。
但是身经百战的你肯定会觉得,前2篇例子中的数据太规范了,如果把数据导入到数据库还是可以方便解决问题的。
因此,本文将使用稍微复杂的数据做演示,充分说明 pandas 是如何灵活处理各种数据。
本文要点:
- 使用 pandas 处理不规范数据。
- pandas 中的索引。
注意:虽然本文是"Python替代Excel Vba"系列,但希望各位读者明白,工具都是各有所长,选择适合的工具,才是最好的。
案例
这次的数据是一个教师课程表。如下图:
- 其中表格中的第3行是班级。诸如"一1",表示是一年级1班,最多8个年级。
- 表格中的1至3列,分别表示"星期"、"上下午"、"第几节课"。
- 前2列有大量的合并单元格,并且数据量不一致。比如星期一有9行,但星期二却只有7行。
- 表格的主要内容是,每天每个班级的每堂课是什么课以及是哪位教师负责。诸如"语文xxx",表示这是语文课,由xxx老师负责。这里的名字按照原有数据做了脱敏。
这是典型的报表输出格式,其中有合并单元格,内容把科目和人名回到一起去。由于案例原有的需求比较繁琐,本文核心是处理数据,因此简化了需求。
不管我们的分析目的是什么,第一步就是要把这份数据整理好,才能应对各种分析。我们开始吧。
导入包
本文所需的包,安装命令如下:
pip install xlwings pip install pandas pip install numpy
建议你安装 anaconda ,那么最难安装的 pandas 和 numpy 都不会是问题。
脚本中导入
设定目标数据格式
我们需要得到最小维度的数据格式,即每天每个班的每节课是哪位老师负责的哪个科目。如下:
为了管理方便,下面会把每个环节的处理放入一个独立的方法中
加载数据
代码如下:
- 由于这次的标题是从第3行开始,因此 wrk.range('a3').current_region 会导致内容包含了前2行。
- .options(np.array),因此我们把整块数据加载到 numpy 的数组中。numpy 数组可以很方便做各种切片。
- header=arr[2] , 取出第3行作为标题。注意索引是从0开始算。
- values=arr[3:],从第4行往后一大片作为值。
- pd.DataFrame(values,columns=header) , 生成一个 DataFrame 。
- .replace(['/','nan'],np.nan),把读取进来的有些无效值替换为 nan,这是为了后续操作方便。
我们来看看数据:
- 注意看左上角有3个 nan ,是因为表格的标题行前3列是空的。
- 由于前2列有合并单元格,出现了很多 nan。
- 此外注意看第3列,把课时序号显示成小数。
处理标题
pandas 的 DataFrame 最大的好处是,我们可以使用列名字操作数据,这样子就无需担心列的位置变化。因此需要把标题处理好。 代码如下:
- cols=df.columns.tolist(),把 df 的字段拿出来。这是一个list
- cols[:3]=['day','apm','num'] ,把列表的前3项的 nan ,替换成我们需要的字段名字。
- df.columns=cols , 表示更新 df 的字段
- df['num'].astype('float').astype('int') ,顺手把 num 字段的小数变整数。这里不能直接转整数,因为 python 怕有精度丢失,直接转换 int 会报错。因此先转 float,再转 int。
再次看看 数据,一切正常:
填充缺失
下一步就是把前2列的 nan 给填充正确。
- df[cols]=df[cols].fillna(method='ffill') , fillna 方法即可填充 nan 。此外 pandas 中有各种内置的填充方式。 ffill 表示用上一个有效值填充。
- 合并单元格很多时候就是第一个有值,其他为空,ffill 填充方式刚好适合这样的情况。
现在数据美如画了。
重塑
要理解 pandas 中的重塑,先要了解 DataFrame 的构成。 如下是一个 DataFrame 的组成部分:
- 红框中的是 DataFrame 的值部分(values)
- 上方深蓝色框中是 DataFrame 的列索引(columns),注意,为什么方框不是一行?是因为 DataFrame 允许多层次索引。类似于平时的复合表头。
- 左方深蓝色框中是 DataFrame 的行索引(index)。本质上是与列索引一致,只是 index 用于定位行,columns 用于定位列。
不要被"多层次索引"这种词汇吓到,其实是我们经常遇到的东西。 下面来看看一个多层次索引的例子:
- 上图的上方有3个层次的列索引,依次从上到下。
- 上图的左方有2个层次的行索引,依次从左到右。
- 我们平时操作 DataFrame 就是通过这两个玩意去定位里面的数据。
如果你熟悉 excel 中的透视表,那么完全可以把行列索引当作是透视表中的行列区域。
理解了索引,那么就要说一下如何变换行列索引。 pandas 中通过 stack 方法,可以把需要的列索引转成行索引。 用上面的数据作为例子,我们需要左边的行索引显示每天上下午的气温和降雨量。如下图:
- 不妨在 excel 的透视表上操作一下,把一个放入列区域的字段移到行区域上,就是上图的结果。
回到我们的例子。我们需要把前3列放入行索引,然后把整个列索引移到行索引上。 代码如下:
- .set_index(['day','apm','num']) , 把这3列放入行索引区域。
- .stack() ,stack 方法默认把最后的列索引区域的最后一个列索引,移到行索引区域的最后。由于目前的 df 只有一个列索引,因此直接调用 stack 即可。
- 此时,由于把唯一的列索引移走了,df 已经没有任何列索引!
- .reset_index(-1) , 把最后的行索引移走,并成为单独的一列。
- 到此,df 又重新有了一层列索引。
看看现在的数据,如下:
剩下的工作则非常简单,主要是把班级和内容分成2列。
数据如下:
最后
本文通过实例展示了如何在 Python 中使用 xlwings + pandas 灵活处理各种的不规范格式表格数据。这种方式尤其适合报表形式的数据。
[源码地址](https://github.com/CrystalWindSnake/Creative/tree/master/python/excel_pandas/3)
请关注本号,后续会有更多相关教程。
相关推荐
- python入门到脱坑经典案例比较大小的6种经典方法
-
在Python中比较两个数的大小是最基础的编程操作之一,以下是6种经典方法及其应用场景,从基础到进阶的完整指南:1.基础比较运算符直接使用>、<、==等运算符:a,b=...
- Python学习 -- 高阶、闭包、回调、偏函数与装饰器探究
-
Python函数作为编程的核心,涵盖了众多令人兴奋的概念,如高阶函数、闭包、回调、偏函数和装饰器。本篇博客将深入研究这些概念,结合实际案例为你解析函数的精妙,以及如何巧妙地运用它们来构建更强大、灵活的...
- python编程中你遇到最恶心的事情是什么
-
在编程的广袤天地里,总有那么些让人抓狂、崩溃,甚至想“砸电脑”的恶心事儿。要说这其中最让人头疼的,莫过于代码中的“神秘Bug”1.可变默认参数的幽灵行为defappend_to(element,...
- python生成器14个常见问题及详解(python生成器定义)
-
以下是Python生成器(Generator)常见问题的详细解答,涵盖使用中的典型疑惑和解决方案:一、基础问题1.生成器只能遍历一次吗?答:是的,生成器是一次性对象,遍历完后需重新创建:defge...
- Python 中 必须掌握的 20 个核心函数及其含义,不允许你不会
-
以下是Python中必须掌握的20个核心函数及其含义,涵盖数据处理、文件操作、面向对象等关键领域,每个函数均附代码示例和应用场景:一、基础必备函数1.print()作用:输出内容到控制台示例...
- 自学Python你卡在了哪一步?被卡了几次?
-
自学Python的放弃点通常集中在以下几个阶段(按学习顺序排列),结合放弃原因和应对建议整理如下:---###**1.环境配置阶段(第1-3天)**-**放弃原因**:-安装Pytho...
- python 10个堪称完美的for循环实践
-
在Python中,for循环的高效使用能显著提升代码性能和可读性。以下是10个堪称完美的for循环实践,涵盖数据处理、算法优化和Pythonic编程风格:1.遍历列表同时获取索引(enumerate...
- python后端学什么(python后端岗位多吗)
-
在当今数字化的时代,Python后端开发成为了众多开发者追逐的热门领域。那么,想要在这个领域崭露头角,我们究竟应该学些什么呢?学习Python后端开发需要掌握全栈技术栈,涵盖从基础语法到分布式...
- Python 列表(List)详解(python中列表用法)
-
列表是Python中最基本、最常用的数据结构之一,它是一个有序的、可变的元素集合。一、列表的基本操作1.创建列表#空列表empty_list=[]empty_list=list()...
- Python 数据转换详解(python将数据转换为字符串)
-
数据转换是编程中非常重要的操作,Python提供了多种方式来实现不同类型之间的转换。下面我将详细讲解Python中的各种数据转换方法。一、基本数据类型转换1.数字类型之间的转换#整数转浮点数...
- python入门 到脱坑 基本数据类型—集合
-
以下是Python集合(Set)的入门详解,包含基础概念、常用操作和实用技巧,帮助初学者快速掌握这一重要数据类型:一、集合基础1.定义集合#空集合(必须用set(),不能用{})empty_se...
- 百看不如一练的247个Python实战案例(附高清PDF完整版教程)
-
百看不如一练,247个python实战案例拿去练手吧希望对大家有帮助!喜欢python和正在学习python的小伙伴可以练练手哦!...
- Python 中 最容易被忽略却极具价值的 8 个特性,80%都不知道
-
1.__slots__:禁止动态属性分配作用:节省内存+防止属性拼写错误示例:classUser:__slots__=['name','age']...
- python中数值比较大小的8种经典比较方法,不允许你还不知道
-
在Python中比较数值大小是基础但重要的操作。以下是8种经典比较方法及其应用场景,从基础到进阶的完整指南:1.基础比较运算符Python提供6种基础比较运算符:a,b=5,3...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python的for循环 (56)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python qt (52)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- centos7安装python (53)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)