python使用openpyxl库读写Excel表格的方法(增删改查操作)
作者:林新发 发布时间:2021-11-29 01:22:43
一、前言
嗨,大家好,我是新发。
最近需要做个小工具,可以通过python
来读写Excel
,实现增删改查操作。以前用的是xlrd
和xlwt
这两个python
库,今天我要讲的是openpyxl
库,我觉得openpyxl
比xlrd
和xlwt
更强大更好用,话不多说,开始吧。
二、安装openpyxl
可以直接通过命令行安装
pip install openpyxl
如果你是内网环境,则可以先在外网下载openpyxl
库然后转到内网再安装。openpyxl
下载地址:https://pypi.org/project/openpyxl/#files
不过如果你下载了openpyxl
,因为openpyxl
还依赖了et_xmlfile
库,所以你还得下载个et_xmlfile
。
如果是用命令行
pip install openpyxl
,则会自动下载依赖。
et_xmlfile
下载地址:https://pypi.org/project/et-xmlfile/#files
安装完毕后,在python
中执行import openpyxl
如果没有报错,则说明安装成功了。
三、openpyxl的使用
1、创建Excel文件
演示代码:
import openpyxl
book = openpyxl.Workbook()
book.save(u'我的表格.xlsx')
运行效果如下,生成了一个excel
表格。
2、加载已存在的Excel文件
上面已经创建了一个表格,我们可以直接加载它。
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
# ...
book.close()
3、创建sheet
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book.create_sheet('我的Sheet')
book.save(u'我的表格.xlsx')
book.close()
运行效果如下:
4、判断某个sheet是否存在
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
if None != book[u'我的Sheet']:
print('我的Sheet 存在')
book.close()
运行结果:
我的Sheet 存在
5、遍历所有Sheet的名称
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
for sheet_name in book.sheetnames:
print(sheet_name)
book.close()
运行结果:
Sheet
我的Sheet
6、写入单元格
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
sheet.cell(1,1).value = 'name'
sheet.cell(2,1).value = '姓名'
sheet.cell(3,1).value = '林新发'
book.save(u'我的表格.xlsx')
book.close()
运行效果
7、获取单元格的各个属性值
为了演示,我在我名字那里加个批注:
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
cell = sheet.cell(3,1)
# 获取单元格的值
print('value:%s'%cell.value)
# 获取行号、列号
print('row: %d, col: %d'%(cell.row, cell.column))
# 获取列名
print('column_letter: %s'%cell.column_letter)
# 单元格的坐标
print('coordinate: %s'%cell.coordinate)
# 单元格数据格式,n: 数字,s:字符串,d: 日期
print('data_type: %s'%cell.data_type)
# 单元格编码格式
print('encoding: %s'%cell.encoding)
# 单元格样式
print('style: %s'%cell.style)
# 单元格批注
print('comment: %s'%cell.comment)
book.close()
运行结果:
value:林新发
row: 3, col: 1
column_letter: A
coordinate: A3
data_type: s
encoding: utf-8
style: 常规
comment: Comment: linxinfa:
多才多艺 by linxinfa
8、遍历单元格
为了演示,我加多一写数据:
一行一行遍历,演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 一行一行遍历
for one_row in sheet.rows:
for cell in one_row:
print(cell, cell.value)
book.close()
运行结果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.B2> 职业
<Cell 'Sheet'.C2> 爱好
<Cell 'Sheet'.A3> 林新发
<Cell 'Sheet'.B3> Unity3D游戏开发工程师
<Cell 'Sheet'.C3> 吉他、钢琴、画画、猫猫、写博客
一列一列遍历,演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 一列一列遍历
for one_col in sheet.columns:
for cell in one_col:
print(cell, cell.value)
book.close()
运行结果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.A3> 林新发
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.B2> 职业
<Cell 'Sheet'.B3> Unity3D游戏开发工程师
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.C2> 爱好
<Cell 'Sheet'.C3> 吉他、钢琴、画画、猫猫、写博客
9、最大行最大列
为了演示,再加点数据。
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
print('max_row: %d, max_column: %d'%(sheet.max_row, sheet.max_column))
book.close()
运行结果:
max_row: 4, max_column: 3
10、删除行或列
为了演示,我再加多写数据。
演示代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 删除第5行
sheet.delete_rows(5)
# 删除第4列
sheet.delete_cols(4)
book.save(u'我的表格.xlsx')
book.close()
运行效果:
11、设置字体
演示代码:
import openpyxl
from openpyxl.styles import Font
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
cell = sheet.cell(4,1)
cell.font = Font(name='微软雅黑',size=18,color='00FFCC99',b=True,i=False)
book.save(u'我的表格.xlsx')
book.close()
运行效果:
12、填充单元格颜色
填充颜色之前
演示代码:
import openpyxl
from openpyxl.styles import PatternFill
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
cell = sheet.cell(4,2)
# 设置填充色
cell.fill = PatternFill('solid',fgColor='FFBB00')
book.save(u'我的表格.xlsx')
book.close()
运行效果:
13、设置行高与列宽
为了演示,我先把行高和列宽改成这样:
演示代码:
import openpyxl
from openpyxl.utils import get_column_letter
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 取第4行
row_4 = sheet.row_dimensions[4]
# 设置行高
row_4.height = 15
# 取第2列
col_2 = sheet.column_dimensions[get_column_letter(2)]
# 设置列宽
col_2.width = 40
book.save(u'我的表格.xlsx')
book.close()
执行效果:
注意,上面我用到了一个get_column_letter
方法,因为column_dimensions
需要的是字母参数,所以我们不能直接传2
,通过get_column_letter(2)
即可得到"B"
,也就是第2列
。
如果要反过来,通过字母逆算出数字,则用column_index_from_string
方法,例:
from openpyxl.utils import column_index_from_string
print(column_index_from_string('B'))
# 输出2
四、结束语
完毕。
博主是Unity3D游戏工程师
,喜欢Unity
的同学,不要忘记点击关注,如果有什么Unity
相关的技术难题,也欢迎留言或私信~
来源:https://blog.csdn.net/linxinfa/article/details/116309278


猜你喜欢
- Pandas DataFrame 取一行数据会得到Series的方法如题,想要取如下dataframe的一行数据,以为得到的还是datafr
- go fmt命令主要是用来帮你格式化所写好的代码文件【很多第三方集成软件都是使用了go fmt命令】一、使用:go fmt <文件名&
- 本文实例讲述了JS实现合并json对象的方法。分享给大家供大家参考,具体如下:一、问题:求json对象合并的方法var a ={"
- 近又开始做网页,发现之前写的页面不规范,这次从头在来,希望一次比一次进步,先从CSS中的标点符号开始吧,这篇做为草稿已经放了很长时间了,还是
- 这篇文章主要介绍了python imread、newaxis用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习
- Python numpy和scipy中没有直接插0的函数和方法,这里使用numpy.insert来实现。1,numpy.inser
- 1.腾讯企业邮箱SMTP服务器地址:smtp.exmail.qq.com,ssl端口为:4652.确保腾讯企业邮箱中开启了SMTP服务:3.
- 这个是升级的版本,比较进阶一点的,相对与之前的文件管理系统,数据只是存储到了内存中,而不是存储到硬盘上,我们想让文件存储到硬盘上的话,一个是
- Vue中子组件调用父组件的三种方法:1.直接在子组件中通过“this.$parent.event”来
- 本文实例讲述了Python 静态方法和类方法。分享给大家供大家参考,具体如下:1. 类属性、实例属性它们在定义和使用中有所区别,而最本质的区
- ASP实现即时显示当前页面浏览人数online.asp文件 <!--#include file="dbconn.a
- 本文实例讲述了Python使用迭代器捕获Generator返回值的方法。分享给大家供大家参考,具体如下:用for循环调用generator时
- 前言:由程序去执行的操作不允许有任何误差,有些时候在测试的时候未出现问题,但是放到服务器上就会报错,而且打印的错误信息并不十分明确。这时,我
- 一、递归递归调用:一个函数,调用的自身,称为递归调用递归函数:一个可以调用自身的函数称为递归函数凡是循环能干的事,递归都能干方法:1、写出临
- MySQL 客户端连接成功后,通过 show [session|global]status 命令 可以提供服务器状态信息,也可以在操作系统上
- Python中默认安装的ftplib模块定义了FTP类,其中函数有限,可用来实现简单的ftp客户端,用于上传或下载文件.FTP的工作流程及基
- 求一个算式a=1b=2c=3 print c*(a/b)运行结果总是0,反复检查拆开以后,发现在Python里,整数初整数,只能得
- 一、管理数据库连接1、使用配置文件管理连接之约定在数据库上下文类中,如果我们只继承了无参数的DbContext,并且在配置文件中创建了和数据
- 前言大家好,我是阿光。本专栏整理了《图神经网络代码实战》,内包含了不同图神经网络的相关代码实现(PyG以及自实现),理论与实践相结合,如GC
- 之前mysql用着好着,可是今天在启动mysql后输入密码出现了闪退,在任务管理器中发现mysql服务没有启动,当手动启动时提示拒绝访问。在