每天一个 Python 库:pandas 办公利器,数据处理效率翻倍!
bigegpt 2025-06-08 19:26 7 浏览
在日常办公中,如果你还在用 Excel 手动处理上千条数据,不如试试 Python 的数据神器——pandas。它可以一行代码读取表格、筛选关键数据、批量导出结果,轻松替代人工处理,提高效率数倍!
本期关键词:Excel 表格读取、字段筛选、数据统计、导出新表。
适用人群:测试开发、数据分析、财务统计、自动化办公人员。
一、为什么选择 pandas?
pandas 是 Python 中最强大的数据分析库之一,主要特点:
- 支持 Excel、CSV、数据库等多种格式
- 提供类 Excel 的表格操作体验(DataFrame)
- 可轻松完成数据清洗、统计、分组、透视等操作
- 与 numpy、matplotlib、openpyxl 高度集成
一句话总结:如果你会用 Excel,就能很快学会 pandas。
学习本来就不是一蹴而就的事,不过只要你肯练、敢用,坚持一阵子,你一定能看到变化!
二、快速上手:读取 Excel 表格
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet)
print("读取成功!前5行数据如下:")
print(df.head())
输出示例:
三、常见操作汇总(适合办公场景)
1. 指定列读取,减小内存压力
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet, usecols=["会计科目", "预算", "实际金额"])
print("读取成功!前5行数据如下:")
print(df.head())
2. 过滤:找出预算为 0 的项
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet)
zero_budget = df[df["预算"] == 0]
print("预算为 0 的数据:")
print(zero_budget)
3. 数据类型与缺失值检查
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet)
print("是否存在缺失值:")
print(df.isnull().sum())
4. 基础统计(均值、中位数、方差等)
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet)
print("快速描述性统计:")
print(df.describe())
字段说明
字段 | 含义说明 |
count | 非空值的数量(剩余百分比 有缺失) |
mean | 平均值 |
std | 标准差(反映波动程度) |
min | 最小值 |
25% | 25 分位点(第一四分位数) |
50% | 中位数(50 分位点) |
75% | 75 分位点(第三四分位数) |
max | 最大值 |
四、导出处理结果
将处理好的数据保存成新文件,方便分享或归档:
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
df = pd.read_excel(file, sheet_name=sheet)
df.to_excel("分析结果.xlsx", index=False)
print("分析结果已导出为 Excel 文件:分析结果.xlsx")
五、实战封装一个小工具函数
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish
@File :D14.py
@Date :2025/5/13
@Author : malijie
"""
import warnings
import pandas as pd
warnings.filterwarnings("ignore", category=UserWarning)
def analyze_excel(file_path, sheet_name):
df = pd.read_excel(file_path, sheet_name=sheet_name)
print("数据读取成功!")
print("字段统计:")
print(df.describe())
# 过滤预算为 0 的记录
filtered = df[df["预算"] == 0]
filtered.to_excel("预算为0记录.xlsx", index=False)
print("已导出预算为0记录!")
if __name__ == '__main__':
file = "总账和预算比较.xlsx"
sheet = "本年累计预算汇总"
analyze_excel(file, sheet)
六、小结:办公数据分析利器非它莫属!
功能 | pandas 实现方式 |
读取 Excel | pd.read_excel() |
选取列 | usecols=[...] |
条件筛选 | df[df["预算"] == 0] |
查看结构 | df.info() |
统计分析 | df.describe() |
导出数据 | df.to_excel("out.xlsx") |
七、可视化预告:数据图表,下期见!
在真实业务中,我们还可以将 pandas 的结果结合 matplotlib 绘图,比如:
- 柱状图对比各部门预算
- 折线图展示月度支出趋势
- 饼图展示成本占比
下期预告:matplotlib 实战教学,用代码画出有颜值的图表!
写在最后
学习是一场长期主义,pandas 的应用远不止这些。
点赞关注不迷路,不错过每一期实战技巧!
后续还有更多自动化测试经验分享~评论区欢迎唠嗑交流!
点头像,发现更多精彩内容!
相关推荐
- 或者这些Joplin插件也可以帮助你的笔记应用再一次强大
-
写在前面距离上次分享《搭建私有全平台多端同步笔记,群晖NAS自建JoplinServer服务》已过去一段时间,大家是否开始使用起来了呢?如果你和我一样已经使用过Joplin有一段时间了,那或许你也会...
- Three.JS教程4 threejs中的辅助类
-
一、辅助类简介Three.js提供了一些辅助类(Helpers)以帮助我们更容易地调试、可视化场景中的元素。ArrowHelepr:创建箭头辅助器;AxisHelper:创建坐标轴辅助器;BoxH...
- 第2章 还记得点、线、面吗(二)(第二章还能敲钟吗)
-
glbgltf模型(webvrmodel)-gltf模型下载定制,glb模型下载定制,三维项目电商网站在线三维展示,usdz格式,vr模型网,网页VR模型下载,三维模型下载,webgl网页模型下载我...
- 如何检查Linux系统硬件信息?从CPU到显卡,一网打尽!
-
你可能会问:“我为什么要关心硬件信息?”答案很简单:硬件是Linux系统的根基,了解它可以帮你解决很多实际问题。比如:性能调优:知道CPU核心数和内存大小,才能更好地调整程序运行参数。故障排查:系统卡...
- SpriteJS:图形库造轮子的那些事儿
-
从2017年到2020年,我花了大约4年的时间,从零到一,实现了一个可切换WebGL和Canvas2D渲染的,跨平台支持浏览器、SSR、小程序,基于DOM结构和支持响应式的,高...
- 平时积累的FPGA知识点(6)(fpga经典应用100例)
-
平时在FPGA群聊等积累的FPGA知识点,第六期:1万兆网接口,发三十万包,会出现掉几包的情况,为什么?原因:没做时钟约束,万兆网接口的实现,本质上都是高速serdes,用IP的话,IP会自带约束。...
- 芯片逻辑调度框架设计 都需要那些那些软件工具
-
设计芯片逻辑调度框架通常需要使用以下软件工具:1.逻辑设计工具:例如Vivado、Quartus、SynopsysDesignCompiler等,用于设计和实现逻辑电路。2.仿真工具:例如Mo...
- ZYNQ与DSP之间EMIF16通信(正点原子领航者zynq之fpga开发指南v3)
-
本文主要介绍说明XQ6657Z35-EVM高速数据处理评估板ZYNQ与DSP之间EMIF16通信的功能、使用步骤以及各个例程的运行效果。[基于TIKeyStone架构C6000系列TMS320C6...
- 好课推荐:从零开始大战FPGA(从零开始的冒险4399)
-
从零开始大战FPGA引子:本课程为“从零开始大战FPGA”系列课程的基础篇。课程通俗易懂、逻辑性强、示例丰富,课程中尤其强调在设计过程中对“时序”和“逻辑”的把控,以及硬件描述语言与硬件电路相对应的“...
- 业界第一个真正意义上开源100 Gbps NIC Corundum介绍
-
来源:内容由「网络交换FPGA」编译自「FCCM2020」,谢谢。FCCM2020在5月4日开始线上举行,对外免费。我们有幸聆听了其中一个有关100G开源NIC的介绍,我们对该文章进行了翻译,并对其中...
- 高层次综合:解锁FPGA广阔应用的最后一块拼图
-
我们为什么需要高层次综合高层次综合(High-levelSynthesis)简称HLS,指的是将高层次语言描述的逻辑结构,自动转换成低抽象级语言描述的电路模型的过程。所谓的高层次语言,包括C、C++...
- Xilinx文档编号及其内容索引(部分)
-
Xilinx文档的数量非常多。即使全职从事FPGA相关工作,没有几年时间不可能对器件特性、应用、注意事项等等有较为全面的了解。本文记录了我自使用Xilinx系列FPGA以来或精读、或翻阅、或查询过的文...
- Xilinx Vivado联合Modelsim软件仿真
-
引言:Xilinx公司Vivado开发软件自带仿真工具,可以实现一般性能的FPGA软件仿真测试,其测试执行效率以及性能都不如第三方专用仿真软件Modelsim强。本文我们介绍下如何进行Vivado20...
- 体育动画直播是怎么做出来的?从数据到虚拟赛场的科技魔法!
-
你是否见过这样的比赛直播?没有真实球员,却能看梅西带球突破?足球比赛变成动画版,但数据100%真实?电竞比赛用虚拟形象直播,选手操作实时同步?这就是体育动画直播——一种融合实时数据、游戏引擎和AI的...
- Dialogue between CPC and political parties of neighboring countries held in Beijing
-
BEIJING,May26(Xinhua)--TheCommunistPartyofChina(CPC)inDialoguewithPoliticalPartiesof...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- resize函数 (64)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- mybatis大于等于 (64)
- xcode-select (66)
- mysql授权 (74)
- 下载测试 (70)
- linuxlink (65)
- pythonwget (67)
- androidinclude (65)
- libcrypto.so (74)
- logstashinput (65)
- hadoop端口 (65)
- vue阻止冒泡 (67)
- jquery跨域 (68)
- php写入文件 (73)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)