Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Python-操作Excel表-openpyxl模块使用

Python-操作Excel表-openpyxl模块使用

作者头像
用户9006224
发布于 2023-10-11 10:52:20
发布于 2023-10-11 10:52:20
76200
代码可运行
举报
文章被收录于专栏:cjz的专栏cjz的专栏
运行总次数:0
代码可运行

openpyxl简介

openpyxl是一个强大的Python库,用于读写Excel(xlsx/xlsm/xltx/xltm)文件。

主要功能和特点如下:

  1. 读取、修改、写入Excel文件,支持格式如xlsx、xlsm等
  2. 支持 Excel 2003 以上格式
  3. 可以很方便地遍历工作表中的行和列
  4. 获取单元格对象后,可以修改单元格的值、样式、格式等
  5. 支持公式、图表、样式、筛选等功能
  6. 可以将Excel数据转换为Python中的字典或列表
  7. 支持 Pandas 的 DataFrame与Excel文件互相转换
  8. 支持数据验证、工作表保护、条件格式设置等高级功能
  9. 支持样式风格、字体设置、对齐方式、颜色渐变等定制格式
  10. 支持 openpyxl、numpy、pandas、Graphs 等库的集成操作

总之,openpyxl作为Python操作Excel的库,提供了非常丰富和强大的功能,可以满足各种 excel 文档处理的需求,是 Python 处理 excel 最重要的库之一。如果需要用 Python 语言处理 Excel 文件,openpyxl是非常好的选择

openpyxl方法详解

工作簿操作

openpyxl.load_workbook():加载存在的Excel工作簿

openpyxl.Workbook():新建一个Excel工作簿

wb.sheetnames:获取工作簿中的所有工作表名

wb.active:获取或设置工作簿的活动工作表

wb.create_sheet():在工作簿中新建一个工作表

wb.remove_sheet():删除工作簿中的一个工作表

wb.save():保存工作簿到文件

工作表操作

ws = wb[sheetname]:根据名称获取工作表

ws.title:获取或设置工作表标题

ws.max_row:工作表总行数

ws.max_column:工作表总列数

ws.cell(row,column):获取单元格

ws.append():在表尾追加行

ws.insert_rows():在指定位置插入行

ws.delete_rows():删除指定行

ws.merge_cells():合并单元格

单元格操作

cell.value:获取或设置单元格的值

cell.row:单元格的行号

cell.column:单元格的列号

cell.data_type:单元格数据类型

cell.font:获取字体对象,用于样式设置

cell.alignment:获取对齐方式对象

cell.border:获取边框对象

cell.fill:获取背景填充对象

cell.number_format:设置数字格式

cell.hyperlink:为单元格设置超链接

数据操作

ws.iter_rows():迭代工作表行

ws.iter_cols():迭代工作表列

ws.rows:以生成器方式返回所有行

ws.columns:以生成器方式返回所有列

ws.values:以嵌套列表方式返回所有值

ws.formula:读取单元格公式

openpyxl方法示例

工作簿操作

创建工作簿:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
wb = openpyxl.Workbook()

获取活动表:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
active_sheet = wb.active 

创建新表:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new_sheet = wb.create_sheet('New Sheet')

获取所有表名:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sheets = wb.sheetnames

切换活动表:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
wb.active = wb['Sheet1']
工作表操作

选择表:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ws = wb['Sheet1']

获取最大行数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
max_row = ws.max_row 

获取最大列数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
max_col = ws.max_column

获取单元格:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cell = ws.cell(row=1, column=1)

获取行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
row = ws[1] 

获取列:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
col = ws['A']

append行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ws.append([1, 2, 3])
单元格操作

赋值:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cell.value = 'Hello'

转换数据类型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cell.number_format = 'yyyy-mm-dd'

设置样式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cell.font = Font(color='00FF0000')

合并单元格:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ws.merge_cells('A1:B3')

调整列宽:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ws.column_dimensions['B'].width = 30
工作簿操作

保存:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
wb.save('example.xlsx')  

加载:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
wb = openpyxl.load_workbook('example.xlsx')

例子

这里是一个使用openpyxl的常见示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import openpyxl

# 载入Excel文件 
wb = openpyxl.load_workbook('example.xlsx')

# 获取活动表
ws = wb.active 

# 读取单元格值
cell_A1 = ws['A1'].value

# 修改单元格值
ws['B1'] = 'Hello World'

# 遍历表格
for row in ws.iter_rows(min_row=1, max_col=3, max_row=2):
    for cell in row:
        print(cell.value)

# 获取最大列数和行数
print(ws.max_column)  
print(ws.max_row)

# 保存修改的Excel文件
wb.save('example_modified.xlsx')

这个示例演示了openpyxl的一些常用功能:

  • 载入Excel文件
  • 获取工作表
  • 读取单元格
  • 修改单元格
  • 遍历工作表
  • 获取最大行列信息
  • 保存修改后的Excel

openpyxl 在Excel中创建简单工作簿和工作表的示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import openpyxl

# 创建新的工作簿
wb = openpyxl.Workbook()

# 获取默认的工作表
sheet = wb.active  

# 修改默认工作表标题
sheet.title = '第一页'

# 创建一个新的工作表
wb.create_sheet('第二页') 

# 在第一页A1单元格输入数据
sheet['A1'] = 'Hello World!'

# 在第二页A1单元格输入数据
wb['第二页']['A1'] = 'Hello World!' 

# 保存Excel文件
wb.save('demo.xlsx')

这个简单的示例做了以下操作:

  • 创建新的工作簿
  • 修改默认工作表的标题
  • 创建新的工作表
  • 在两个工作表的A1单元格写入数据
  • 保存工作簿为Excel文件

就可以用几行代码通过openpyxl创建一个带有多sheet的Excel工作簿。我们可以继续往工作表中添加数据、格式等来生成更丰富的Excel文件。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
openpyxl:Python的Excel操作库
luckpunk
2023/09/27
7430
openpyxl:Python的Excel操作库
Python自动化办公-处理Excel文档
Python自动化办公-处理word文档,这次分享python处理excel的方法
用户9925864
2022/07/27
4880
Python自动化办公-处理Excel文档
Python3 读取和写入excel xlsx文件 使用openpyxl
•win32com:不仅仅是excel,可以处理office;不过它相当于是 windows COM 的封装,新手使用起来略有些痛苦。
用户7886150
2020/12/23
3.2K0
openpyxl的简单入门
openpyxl模块只支持xlsx/xlsm/xltx/xltm格式,不支持xls格式。
JQ实验室
2022/07/03
1.1K0
Python之Excel 优雅操作手法 精选
一直想写这一篇,却又一直被事情拖着。 我带的一个项目团队正好进行到这一块儿了,正好,将这事儿办了,以后要用的时候也不用到处找。 半点不求人。
看、未来
2021/09/18
5710
Python Linux自动化运维 -- Openpyxl Excel处理
python模块openpyxl pip install openpyxl 使用load_workbook函数读取一个已有的excel文件。 使用Workbook的get_sheet_by_name方法获取Worksheet对象。 使用Worksheet的cell方法获取Cell对象。 类 Workbook Workbook对应Excel工作簿 Workbook对象的部分属性: active:获取活跃的Worksheet; read_only:是否以read_only模式打开excel文件; encod
用户3013098
2022/06/01
2K0
Python Linux自动化运维 -- Openpyxl Excel处理
Python自动化:Python操作Excel的多种方式Pandas+openpyxl+xlrd
使用pandas操作Excel文件主要涉及读取(read_excel)和写入(to_excel)两个主要操作。
小白的大数据之旅
2024/11/20
5550
openpyxl
openpyxl用来操作xlsx文件(不支持xls文件) 以下用wb代表WorkBook类,ws代表WorkSheet类,cell代表单元格。
TomatoCool
2023/07/30
3420
Excel自动化办公
安装 pip install openpyxl==3.0.7 基本操作 import openpyxl print(openpyxl.__version__) # 用openpyxl读取excel表格 wb = openpyxl.load_workbook('信息表.xlsx') print(wb) # 获取工作蒲sheet表名称 sheet1 = wb.sheetnames print("sheet表名称:\n", sheet1) # 获取指定sheet对象 sheet = wb['基本信息'] pr
shaoshaossm
2022/12/26
4460
'python之excel读写报表统计入门'
随着python版本升级, 版本在2.7以上的,在安装Python的时候,已经自动安装好了pip.pip是下载相关依赖的引擎,每个人的理解不一样.相当于java中的mvn,也相当于node中的npm,可以使用pip install 模块名 的方式下载所需的依赖.
java攻城狮
2021/02/26
9990
'python之excel读写报表统计入门'
python3 openpyxl操作excel
在日常工作中,避免不了需要操作excel文件的情况,如果还带有需要对excel的内容进行格式设定、合并单元格等需求,那么可以使用openxl来解决处理。
Devops海洋的渔夫
2019/10/10
2.8K0
python3 openpyxl操作excel
python3操作Excel (一)
excel表中有图像,需要安装pillow库。 pip install Pillow
py3study
2020/01/06
9590
超超长篇 - 手把手带你用python玩转Excel
gitee:https://gitee.com/xiaozai-van-liu/mwj_utils
梦无矶小仔
2024/06/18
9360
超超长篇 - 手把手带你用python玩转Excel
python3编程基础:操作excel(
python中操作excel的模块有很多,比如xlrd,xlwt,openpyxl,xlutils等。前两个是一套,一个读一个写。注意:xlwt模块,只能支持到excel2003,也就是扩展名为.xls的excel;xlrd模块可以支持读取07版本,也就是.xlsx扩展名的excel。每个模块都有一些优缺点,本文以openpyxl模块为例来进行介绍。
py3study
2020/01/13
8070
Python操作Excel文件(2)
文章背景:Excel是Window环境下流行的、强大的电子表格应用。openpyxl模块让Python程序能够读取和修改Excel电子表格文件。下面介绍如何通过Python操作Excel文件。
Exploring
2022/09/20
3450
Python操作Excel文件(2)
Python 自动化指南(繁琐工作自动化)第二版:十三、使用 EXCEL 电子表格
Excel 是一个流行且功能强大的 Windows 电子表格应用。openpyxl模块允许您的 Python 程序读取和修改 Excel 电子表格文件。例如,您可能有从一个电子表格中复制某些数据并粘贴到另一个电子表格中的枯燥任务。或者,您可能必须遍历数千行,然后只挑选出其中的一小部分,根据某些标准进行小的编辑。或者你可能不得不查看数百份部门预算的电子表格,寻找任何赤字。这些正是 Python 可以为您完成的那种枯燥、无需动脑的电子表格任务。
ApacheCN_飞龙
2023/04/04
18.4K0
Python 自动化指南(繁琐工作自动化)第二版:十三、使用 EXCEL 电子表格
python openpyxl 常用功能
1. 安装 pip install openpyxl 1 2. 打开文件 ① 创建 from openpyxl import Workbook # 实例化 wb = Workbook() # 激活 worksheet ws = wb.active 12345 ② 打开已有 >>> from openpyxl import load_workbook >>> wb2 = load_workbook('文件名称.xlsx') 12 3. 储存数据 # 方式一:数据可以直接分配到单元格中(可以输入公式)
用户5760343
2022/05/13
7520
Python | 使用Python操作Excel文档(一)
openpyxl操作Excel的第三方库,作者是Eric Gazoni, Charlie Clark。您也可以访问openpyxl的官方网站通过官方手册进行学习。同时附上官方网站的地址:
LogicPanda
2019/07/30
2.4K0
常用模块 - openpyxl模块
首先介绍下Excel的一些基本概念,Workbook相当于是一个文件,WorkSheet就是文件里面的每个具体的表,比如新建Excel文件里面的“Sheet1”,一个Workbook里面有一个或多个WorkSheet。
py3study
2020/01/17
1.1K0
python openpyxl
from openpyxl import Workbook wb = Workbook() #创建文件对象
用户5760343
2022/05/13
8230
相关推荐
openpyxl:Python的Excel操作库
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文