python除了熟悉的pandas,openpyxl库也很方便的支持编辑Excel表

news2024/12/26 7:34:36

图片

excel表格是大家经常用到的文件格式,各行各业都会跟它打交道。之前文章我们介绍了使用openpyxl和xlrd库读取excel表数据,使用xlwt库创建和编辑excel表,在办公自动化方面可以方便我们快速处理数据,帮助我们提升效率。

python之openpyxl快速读取Excel表内容

测开不得不会的python之xlrd库读取excel表内容

python之xlwt库编辑写入excel表内容

本次我们介绍使用openpyxl创建和编辑excel表。

官网文档:
https://openpyxl.readthedocs.io/en/stable/

官网显示,openpyxl是一个用于读/写Excel2010后缀为XLSX/XLSM/XLTX/XLTM文件的python库。

了解下电脑中的excel表格文件格式

微软或者金山的excel表格编辑保存时一般要选择文件后缀,有xls和xlsx两类。

xls和xlsx后缀文件的主要区别:

  • 文件格式:xls是二进制格式,而xlsx是基于XML的压缩方式。

  • 版本:xls是Excel 2003及以前版本生成的文件格式,而xlsx是Excel 2007及以后版本生成的文件格式。

  • 兼容性:xlsx格式向下兼容,而xls格式不支持向后兼容。

安装openpyxl库

pip install openpyxl -i https://mirrors.aliyun.com/pypi/simple/

目前最新版本3.1.5,安装后目录结果如下,初始化文件__init__.py文件如下:

图片

使用openpyxl库

初始化文件__init__.py文件已经导入了Workbookl类:

图片

该函数用于创建和编辑excel表,使用时我们只需要通过如下命令直接导入即可:

from openpyxl import Workbook

该Workbook类可以创建和操作sheet页对象(class为openpyxl.worksheet. worksheet.Worksheet),通过sheet对象不同的函数来编辑表格中的内容。

创建并编辑,保存Excel表

1导入openpyxl库的Workbook类

from openpyxl import Workbook

2用一个图展示下编辑表格常用的函数(WorkBook和Worksheet类中的函数)

图片

3操作sheet对象

首先我们先初始化Workbook对象

wb = Workbook()

我们编辑表格,其实编辑的都是表格下方的sheet页,所以我们初始化后要先创建sheet页对象,当然也可以复制,删除,移动,复制sheet页对象。

a 创建sheet对象

1)使用wb.active属性函数获取sheet对象

#获取表格sheet页,一般是默认第1个,也可以选择其他并保存后,获取的就是保存后的sheet页对象
sheet = wb.active

2)使用create_sheet函数创建sheet对象

图片

  • 参数title代表 sheet页的名称,可以不填。

  • 参数index:传值时代表创建第几个sheet页;不传值时,则按照顺序依次创建。

测试代码:创建三个sheet页对象

wb = Workbook()
sheet0 = wb.create_sheet('sheet0',0)
sheet1 = wb.create_sheet('sheet1',1)
sheet2 = wb.create_sheet('sheet2')

b 获取sheet对象

1)当创建了多个sheet对象后,可指定获取第N个sheet页对象

wb.active = 1
sheet = wb.active

2)使用wb._sheets获取所有sheet页对象列表,并通过index获取单个sheet页对象

sheet = wb._sheets[0]

3)使用wb.sheetnames获取所有sheet页名称,并通过wb[sheetname]获取sheet页对象

sheetnames = wb.sheetnames
print(sheetnames )
sheet = wb['functions']

4)使用wb.worksheets获取所有sheet页对象列表,并通过index获取单个sheet页对象

print(wb.worksheets)
sheet = wb.worksheets[0]

c 复制sheet页对象

函数copy_worksheet传入已存在的sheet对象,并复制一个对象。

图片

测试代码:

wb = Workbook()
sheet0 = wb.active
sheet1 = wb.copy_worksheet(sheet0)
wb.save(‘1.xlsx’) #保存文件

结果:

图片

d 删除sheet对象

有2种方式删除sheet对象:

wb.remove(worksheet) or del wb[sheetname]

图片

测试代码:

wb = Workbook()
#先创建三个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
sheet1 = wb.create_sheet('sheet1',1)
sheet2 = wb.create_sheet('sheet2')
#删除两个对象
wb.remove(sheet0)
del wb['sheet1']
wb.save(‘2.xlsx’) #保存文件

结果:sheet0和sheet1被删除

图片

e move_sheet:用于移动对象

函数move_sheet可以将sheet对象移动offsheet偏移量。

参数sheet可以传sheet对象或者sheet的名称。

图片

测试代码:

wb = Workbook()
#先创建三个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
sheet1 = wb.create_sheet('sheet1',1)
sheet2 = wb.create_sheet('sheet2')
#移动两个对象
wb.move_sheet(sheet0,3)
wb.move_sheet('sheet1',4)
wb.save('3.xlsx') #保存文件

结果:sheet0和sheet1移动到了右边位置

图片

4 编辑sheet页

a cell()函数:设置单元格的值

cell函数的参数:

  • row代表第几行,column代表第几列,需要大于等于1,都则会报错,
  • value参数如果传值会设置为该单元格的值

图片

以上函数返回的是单元格对象,class为openpyxl.cell.cell.Cell

图片

Cell对象的几个属性:

  • value :单元格的值
  • row:单元格所在的行数
  • column:单元格所在的列数
  • data_type:单元格内容对应的数据类型

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#填入第1行第1列和第1行第2列的值
sheet0.cell(1,1,'hello')
sheet0.cell(1,2,'python')
wb.save('3.xlsx') #保存文件

结果:

图片

b 像设置列表元素一样输入和删除单元格的值

之前文章我们讲过(python中类class的魔法方法),在类中实现了__getitem__、__setitem__,__delitem__魔法方法,我们就可以对该类的对象,像使用list列表一样获取、设置、删除元素。

图片

  • 按照如下格式输入单元格内容:sheet0['A1'] =‘hello’

  • 按照如下格式删除单元格内容:del sheet0['B1']

解释:A1代表第1列第1行的单元格,B1代表第2列第1行的单元格; 相信大家已经清楚的知道字母代表列,数字代表行(跟我们打开表格看到的是一样的)

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#填入第1行第1列和第1行第2列的值
sheet0['A1'] = 'hello'
sheet0['B1'] = 'python'
del sheet0['B1'] 
wb.save('4.xlsx') #保存文件

结果:单元格B1的内容又被删掉了

图片

c append()函数:按行批量添加可迭代对象的元素

通过下图可知,参数需要为可迭代对象:列表/元组/字典等,默认从第1行开始写入;

如果为字典,则字典的key需要满足大写字母A到ZZZ,或者为数字,代表在第几列输入字典的value。

图片

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#设置列表和字典变量
data1 = ['hello','python','my','friend']
data2 = {'A':'hello','C':'python'}
data3 = {1:'hello',2:'python',4:'friend'}
sheet0.append(data1)
sheet0.append(data2)
sheet0.append(data3)
wb.save('6.xlsx') #保存文件

结果:

图片

d 插入/删除行和列

insert_rows,insert_cols,delete_rows,delete_cols四个函数分别代表插入行/插入列/删除行/删除列

参数都是有两个idx和amount:

  • idx代表插入或者删除的位置
  • amount代表插入或者删除的数量(amount值>=1)

图片

图片

比如 insert_rows(2,3) 代表在第2行上面插入3行

比如 insert_cols(2,3) 代表在第2列左面插入3列

比如 delete_rows(5,3) 代表在第5行上面删除3行

比如 delete_cols(5,3) 代表在第5列左面删除3列

e move_range:移动一个范围内的单元格

图片

move_range 方法需要几个参数:

  • cell_range:一个字符串,表示要移动的单元格范围(例如 'A1:C3')。
  • rows:一个整数,表示要向下移动的行数(正数表示向下,负数表示向上)。
  • cols:一个整数,表示要向右移动的列数(正数表示向右,负数表示向左)。

注意:移动时单元格会被覆盖,请务必小心。

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#设置列表和字典变量
data1 = ['hello','python','my','friend']
data2 = {'A':'hello','C':'python'}
data3 = {1:'hello',2:'python',4:'friend'}
sheet0.append(data1)
sheet0.append(data2)
sheet0.append(data3)
#移动一个范围
sheet0.move_range('A1:C1',2,3)
wb.save('6.xlsx') #保存文件

f merge_cells函数用于合并单元格

合并后的单元格将拥有合并前单元格的数据和样式,并且可以跨越多个行和列。合并单元格可能会导致原有数据丢失,大家要慎重使用。

图片

参数介绍:

  • range_string:指定要合并的单元格区域,例如'A1:B2'表示合并从A1到B2的单元格区域。
  • 其他四个参数:分别表示合并的起始行、起始列、结束行和结束列。比如(1, 1, 3,2)表示合并第1行第1列到第3行第2列的单元格。

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#设置列表和字典变量
data1 = ['hello','python','my','friend']
data2 = {'A':'hello','C':'python'}
data3 = {1:'hello',2:'python',4:'friend'}
sheet0.append(data1)
sheet0.append(data2)
sheet0.append(data3)
#以下两种方式 同样的效果
sheet0.merge_cells('A1:C2')
sheet0.merge_cells(start_row=1,start_column=1,end_row=3,end_column=2)
wb.save('6.xlsx') #保存文件

结果:

图片

g unmerge_cells 取消合并单元格

跟merge_cells函数功能相反,取消合并的单元格,参数跟merge_cells一致,参考上面的介绍

图片

h 属性函数最大行/最大列/最小行/最小列

max_row: 代表最大行

max_column:代表最大列

min_row: 代表最小行

min_column:代表最小列

图片

测试代码:

wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#设置列表和字典变量
data1 = ['hello','python','my','friend']
data2 = {'A':'hello','C':'python'}
data3 = {1:'hello',2:'python',4:'friend'}
sheet0.append(data1)
sheet0.append(data2)
sheet0.append(data3)
#打印最大行 最大列等信息
print(f'max_row: {sheet0.max_row}')
print(f'max_colunn: {sheet0.max_column}')
print(f'min_row: {sheet0.min_row}')
print(f'min_column: {sheet0.min_row}')
wb.save('6.xlsx') #保存文件

结果:

max_row: 3

max_colunn: 4

min_row: 1

min_column: 1

​​​​​​​i add_image:在单元格中添加图片

  • 参数image需要传入一个image对象,而不是某个图片;
  • anchor填入单元格位置,比如“A1”

image对象依赖另一个库pillow,我们先安装这个库:

pip install pillow -i ​​​​​​​https://mirrors.aliyun.com/pypi/simple/

测试代码:

from openpyxl.drawing.image import Image
from openpyxl import Workbook
wb = Workbook()
#先创建1个sheet对象
sheet0 = wb.create_sheet('sheet0',0)
#定义image对象

imageins = Image('xxxx.jpg')

#在单元格A1处添加图片
sheet0.add_image(imageins,'A1')
wb.save('6.xlsx')  #保存文件

共勉:东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳。

----感谢读者的阅读和学习,点个赞和关注吧,谢谢大家。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2251730.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JMeter 并发策略-针对准点秒杀场景的压测实现

一、场景的压测实现 1,创建线程组,10并发用户执行5次; 2,创建 Synchronizing Timer 元件,用于同步线程,设置同步元件 Synchronizing Timer 3,创建 http 请求4,创建 view results in table 元件…

损失函数分类

1. NLLLoss(负对数似然损失) 定义: 直接对预测的概率 p(yi) 的负对数求平均。通常配合 Softmax 使用,输入为对数概率。 优点: 对离散分类问题效果良好。更灵活,用户可以自行计算 Softmax。 缺点&#x…

【热门主题】000072 分布式数据库:开启数据管理新纪元

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 【热…

算法笔记:力扣148. 排序链表

思路: 将链表中的节点一一取出放到list集合中,然后通过Comparator实现排序,对排序好的list节点一一取出,组成排序好的新链表。 关键思路: Comparator实现对ListNode的排序; 💡注意&#xff…

Kafka知识体系

一、认识Kafka 1. kafka适用场景 消息系统:kafka不仅具备传统的系统解耦、流量削峰、缓冲、异步通信、可扩展性、可恢复性等功能,还有其他消息系统难以实现的消息顺序消费及消息回溯功能。 存储系统:kafka把消息持久化到磁盘上&#xff0c…

MacOS安装MySQL数据库和Java环境以及Navicat

安装MySQL 去官网下载:MySQL 下载好后安装,在设置里往下滑,出现了这样,就代表安装成功了 接下来配置环境: 首先在我们的设备上找到终端并打开,输入 vim ~/.bash_profile(注意vim后面的空格),输入完成后点击…

Css、less和Sass(SCSS)的区别详解

文章目录 Css、less和Sass(SCSS)的区别详解一、引言二、CSS 简介1.1、CSS 示例 三、Less 简介2.1、Less 特性2.2、Less 示例 四、Sass(SCSS)简介3.1、Sass 特性3.2、SCSS 示例 五、总结 Css、less和Sass(SCSS&#xff…

misc-好久不见17

wireshark_secret Ctrlshirtv 8、热心助人的小明同学 使用工具volatility查看镜像的信息 volatility_2.6_win64_standalone -f image.raw imageinfo 列出所有用户和密码: volatility_2.6_win64_standalone -f image.raw --profileWin7SP1x86_23418 hashdump Xi…

利用PyTorch Profiler实现大模型的性能分析和故障排查

本文介绍PyTorch Profiler结合TensorBoard分析模型性能,分别从数据加载、数据传输、GPU计算、模型编译等优化思路去提升模型训练的性能。最后总结了一些会导致CPU和GPU同步的常见的PyTorch API,在使用这些API时需要考虑是否会带来性能影响。 PyTorch Pr…

关于IDE的相关知识之三【插件安装、配置及推荐的意义】

成长路上不孤单😊😊😊😊😊😊 【14后😊///C爱好者😊///持续分享所学😊///如有需要欢迎收藏转发///😊】 今日分享关于ide插件安装、配置及推荐意义的相关内容…

ECharts柱状图-交错正负轴标签,附视频讲解与代码下载

引言: 在数据可视化的世界里,ECharts凭借其丰富的图表类型和强大的配置能力,成为了众多开发者的首选。今天,我将带大家一起实现一个柱状图图表,通过该图表我们可以直观地展示和分析数据。此外,我还将提供…

预处理详解(完结篇)

⽬录 一. 什么是预处理 c 1 预定义符号 2. #define定义常量 3 . #define定义宏 4. 带有副作⽤的宏参数 5. 宏替换的规则 6 宏函数的对⽐ 三 #和## 四 命名约定 五. #undef 一 什么是预处理 有许多文件中都内容我们是看不懂的,那怎么才能令…

【k8s】监控metrics-server

metrics-server介绍 Metrics Server是一个集群范围的资源使用情况的数据聚合器。作为一个应用部署在集群中。Metric server从每个节点上KubeletAPI收集指标,通过Kubernetes聚合器注册在Master APIServer中。为集群提供Node、Pods资源利用率指标。 就像Linux 系统一样…

ERP 入库生产第一个版本完成

剩下的逻辑都是基于入库表达操作,资源划分,在销售,出库 windows 下直接部署 mysql 数据库,更轻量一些

ESP32-S3模组上跑通ES8388(12)

接前一篇文章:ESP32-S3模组上跑通ES8388(11) 二、利用ESP-ADF操作ES8388 2. 详细解析 上一回解析了es8388_init函数中的第5段代码,本回继续往下解析。为了便于理解和回顾,再次贴出es8388_init函数源码,在…

对于相对速度的重新理解 - 15

换一个视角看待能量可能一切都更为清晰,从, 可以意识到,最终质量 指的是 的数量。这个数量就是 我们可以去除电性振动和磁性振动的影响,把这两种振动的影响归结在 里面,这就像是,有一百万个某种物体&#x…

记一次腾讯云海外服务器http能正常访问https访问拒绝问题处理过程

最近双十一, 购了一台腾讯云的海外服务器, 开通后就是一堆的服务器软件安装数据上传和配置,没想到,等待配置完成后才发现https无法正常访问,于是开启了自查。 1. 检查nginx软件的ssl配置 nginx http https配置参考 server {l…

Java 单元测试模拟框架-Mockito 的介绍

Mockito 是什么 Mockito 是一个用于单元测试的模拟框架,基于它可以使用简洁易用的API编写出色的测试。 Mockito 允许开发人员创建和管理模拟对象(mock objects),以便在测试过程中替换那些不容易构造或获取的对象。 Mockito的基本…

分享一款 Vue 图片编辑插件 (推荐)

💥本篇文章给大家分享一款强大到没朋友的Vue图片编辑插件,可以对图片进行旋转、缩放、裁剪、涂鸦、标注、添加文本等,快来试试并收藏吧!💕 这是一款对图片进行旋转、缩放、裁剪、涂鸦、标注、添加文本在线处理的图片处…

在基于控制器的 API 和最小 API 之间进行选择

文章目录 ASP.NET Core 支持两种创建 API 的方法:基于控制器的方法和最小 API。 API 项目中的控制器是派生自 ControllerBase 的类。 最小 API 在 Lambda 或方法中使用逻辑处理程序定义终结点。 本文解释了这两种方法之间的差异。 最小 API 的设计默认隐藏了主机类…