Python处理excel数据,原来这么简单,VBA要尴尬了
off999 2024-10-08 06:17 17 浏览 0 评论
工作中经常会遇到一些每天都要进行的重复操作,没一点技术含量,做起来却费时费力,还时不时出点小错。为应对这种情况,有些人会用VBA进行处理。但编辑了VBA功能的文件通用性不好,遇到领导、同事的excel未开启宏,就用不了。其实,用Python处理excel数据,比VBA更高效,而且还简单。我们来看看如何用Python处理excel数据:
一、Python处理Excel的方式
python对excel的操作是通过导入相应的功能库,然后利用库里的模块写代码实现的。与excel有关的库一般包括:xlrd、xlwt、xlutils、openpyxl、xlsxwriter,这五个库用法各异,综合来说,优先推荐opengyxl,不建议全部导入有备无患的想法。各库功能用法说明如下:
1、xlrd:读取excel文件的库
导入后,执行对excel文件打开、读取数据操作。比如:
import xlrd # 导入xlrd库 wb = xlrd.open_workbook(r"e:\test.xls") sht = wb.sheets()[0] aa = sht.name bb = sht.cell_value(1, 1) print(aa, bb)
代码解析:
1、导入xlrd库
2、打开e:\test.xls文件,wb代表该打开的工作薄
3、sht代表wb工作薄里第一个表单
4、aa代表sht表单的表单名
5、bb代表sht表单里第2行第2列单元格的值
6、在终端输出aa、bb,检验运行效果。
此时,若想修改bb单元格的值,是不可以的,因为导入的xlrd库只支持读取,不支持写入、修改。
2、xlwt:向excel表格写入数据的库
导入后,执行创建新表格,写入数据操作,比如:
import xlwt wb = xlwt.Workbook() sht = wb.add_sheet("表1") sht.write(0, 0, '测试数据') wb.save(r"e:\python\创建表.xls")
代码解析:
1、导入xlwt库
2、wb代表刚创建的工作薄
3、sht代表在wb工作薄中创建表单,表单名为“表1”
4、在sht表单中的a1单元格写入“测试数据”
5、保存工作薄路径及文件名为:"e:\python\创建表.xls"
3、xlutils:修改excel文件的库
导入后,执行打开既有excel表格数据的修改等操作,比如:
import xlrd import xlutils as cp wb = xlrd.open_workbook(r"e:\test.xls") aa = cp.copy.copy(wb) sht = aa.get_sheet(0) sht.write(1, 1, "xxx") aa.save(r"e:\test.xls")
代码解析:
1、2、导入xlrd库和xlutils库
3、打开"e:\test.xls"文件
4、aa代表复制刚才打开的文件
5、sht代表复制的文件第一个表单
6、向sht表单第2行第2列写入“XXX”
7、还是用原名保存文件,完成文件内容的修改。
以上三个库第一次使用时可能会提示报错:
这是因为系统里没有对应的xlrd库造成的,我们用pip方式先给系统里安装库:打开cmd命令,输入
pip install xlrd
回车,开始安装。稍等片刻,出现下面的界面即完成安装:
再回到vscode界面,提示已经没问题了。
同理,通过pip install xlwt,ipip install xlutils完成xlwt库和xlutils库的导入,就可以放心使用了。
以上库存在的不足:
1、三个库分别有各自的功能,一般需要同时使用才能满足实际使用,用起来比较麻烦。
2,xlwt库和xlutils库写入和修改操作,都只能保存为.xls格式,若保存为.xlsx格式,则打开文件时会提示格式错误。
3、写入操作后,未保存文件时读取不到刚写入的数据,读取的还是未写入之前的数据,只有保存后在读取才能得到正确结果。
4、openpyxl库
用opengyxl库操作excel,则能轻松解决上面三个库的不足,且代码更符合excel使用习惯。
import openpyxl wb = openpyxl.load_workbook("e:\dest.xlsx") sht = wb['sy'] print(sht['a2'].value) sht['a2'].value = "新名字" print(sht['a2'].value) wb.save("e:\dest.xlsx")
代码解析:
1、导入openpyxl库
2、打开e:\test.xls文件,wb代表该打开的工作薄
3、sht代表wb工作薄里名字为sy的表单
4、读取输出sht表单a2单元格的内容
5、给sht表单a2单元格写入数据“新名字”
6、再次读取输出sht表单a2单元格的内容,会发现本次输出的就是刚才写入的"新名字"
7、保存文件,不更改文件名。
不足之处:不能操作.xls文件。
5、xlsxwriter库:可在excel文件里写入并设置图表的库,有图表要求的,后期专题学习。
6、com调用Excel的API库:通过COM调用,实现Python对excel操作的方法,写法与VBA非常相似,个人认为还不如python的openpyxl好用,且设置过程相对复杂,以后有机会再介绍。
理论结合实际,我们用一个真实案例来体验一下python处理excel数据的感觉:
文件“删除最小值.xlsx”中,(A:D)四列数据,希望删除每行的最小值,保留三个值,写入到后面(F:H)列中。
1、导入openpyxl库来处理:
import openpyxl
2、打开文件,定义表单:
wb = openpyxl.load_workbook("e:\删除最小值.xlsx") sht = wb['数据']
3、数据处理(请自动忽略粗糙的逻辑思路)
for i in range(2, 8): minnum = sht.cell(i,1).value if sht.cell(i, 2).value < minnum: minnum = sht.cell(i,2).value if sht.cell(i,3).value < minnum: minnum = sht.cell(i,3).value if sht.cell(i, 4).value < minnum: minnum = sht.cell(i, 4).value k = 0 for j in range(1, 5): if sht.cell(i, j).value > minnum: k += 1 sht.cell(i, k+5).value = sht.cell(i, j).value print(sht.cell(i, k+5).value, end=' ') print()
4、保存文件:
wb.save("e:\python\删除最小值.xlsx")
运行后通过print代码在终端显示了结果:
打开表格,数据已经完成了填入:
总结:
总的来说,用openpyxl库让python处理excel还是比较容易的,符合python容易上手的特点,让大家把精力多放在问题解决思路上,而不是浪费在学习代码写法规则上。
相关推荐
- python基础模块三剑客:sys、os、shutil(增加示例代码)
-
注:上个篇由于不熟悉头条号编辑器,导致示例代码丢失。现在全部以图片的形式加回。有同学问了个问题:在python里如何复制、删除、重命名文件?有个同学知道os.system(),就回答说:os.syst...
- Python常用文件操作库使用详解(python 对文件操作)
-
Python生态系统提供了丰富的文件操作库,可以处理各种复杂的文件操作需求。本教程将介绍Python中最常用的文件操作库及其实际应用。一、标准库核心模块1.1os模块-操作系统接口主要功能:文件...
- 你知道Python 如何进行高效的代码重构吗?
-
点赞、收藏、加关注,下次找我不迷路写出高质量的代码是每个程序员的追求。而代码重构作为提升代码质量的重要手段,却常常被新手忽视。很多新手在编写代码时,只关注功能是否实现,却不注重代码的结构和可维护性,...
- Python常用内置模块介绍——文件与系统操作详解
-
Python提供了多个强大的内置模块用于文件和系统操作,下面我将详细介绍最常用的几个模块及其核心功能。1.os模块-操作系统交互os模块提供了与操作系统交互的接口,包括文件/目录操作、进程管理、环...
- Python的tarfile模块解压缩.tar/.tar.gz等文件
-
python中的标准库tarfile模块可以帮助我们快速压缩或者解压后缀为.tar/.tar.gz/.tar.bz2/.tar.xz的文件。01、tarfile核心类与函数介绍使用方法因为tarfil...
- 批量重命名工具,Bulk Rename Utility软件体验
-
平常在电脑上处理电子文件,经常在得到文件本身时,没有空闲和精力去为文件重命名,像是一张图片,要作为下一个步骤的素材。而处理完事过后就不理它了,顺手直接丢回收站或者放在硬盘里。但是想把文件存档和提交给上...
- 照片怎样重命名?方法有四种(照片怎么可以重命名)
-
照片怎样重命名?照片在我们日常生活中扮演着越来越重要的角色,但是有时候,我们需要对照片进行重命名,以便更好地组织和查找它们,这样也可以大大提高我们的效率。在这篇文章中,我们将介绍四种简单的方法,让你轻...
- 你需要批量创建文件夹并命名吗,给你推荐几个方法
-
小李是一家设计公司的项目经理,最近接了一个大项目,需要整理大量的设计稿。每个设计稿都需要单独创建一个文件夹,以方便团队成员协作。手动创建文件夹效率太低,而且容易出错。小李在网上搜索了各种方法,尝试了P...
- 怎样批量重命名一个工作簿中的所有工作表
-
上篇文章,Python数据的选取和处理,阅读量93,收藏15,没有评论。目前正在复习Python+Excel实现办公自动化,有兴趣的可以一起讨论,共同提高。花了近4个小时终于把6个分部的统计工作表做好...
- Windows如何批量修改文件后缀名(电脑如何批量修改文件后缀名)
-
在Windows系统中药批量修改文件后缀名的方式非常多,每个方法的优缺点各有不同,下面通过几个常见的方式给大家介绍下,Windows如何批量修改文件后缀名的。给有需要的朋友几个参考。方法一:使用文件资...
- Python3+ 变量命名全攻略:PEP8 规范 + 官方禁忌 + 实战技巧,全搞懂!
-
Python3+变量命名规则与约定详解一、官方命名规则(必须遵守)1.合法字符集变量名只能包含:大小写字母(a-z,A-Z)数字(0-9)下划线(_)2.禁止数字开头合法:user_age,...
- python代码实现读取文件并生成韦恩图
-
00、背景今天战略解码,有同学用韦恩图展示各个产品线的占比,效果不错。韦恩图(Venndiagram),是在集合论数学分支中,在不太严格的意义下用以表示集合的一种图解。它们用于展示在不同的事物群组之...
- python学习第二天:用Pycharm新建的第一个程序
-
分享第一次使用Pycharm学到的内容第一次打开得到上面图片projects:项目customize:自定义plugins:插件learn:学习newproject新建项目聪明如我在插件那里找到了汉...
- 如何编写第一个Python程序(python第一个代码)
-
一、第一个python程序[掌握]python:python解释器,将python代码解释成计算机认识的语言pycharm:IDE(集成开发环境),写代码的一个软件,集成了写代码,...
- Python文件读写操作详解:从基础到实战
-
Python文件的读写操作在Python中,文件操作非常常见,可以通过内建的open()函数进行文件的读取、写入、创建等操作。理解文件操作的模式和with语句对于确保代码的简洁性和效率至...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python重命名文件 (54)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)