python 标准库之openpyxl的常规操作

目录

openpyxl(Excel文件处理模块)

读sheet

读sheet中单元格

合并单元格

openpyxl模块基本用法

安装方法

基本使用

读取Excel文档

(一)获取工作表

(二)获取单元格

(三)获取行和列

写入Excel文档

(一)写入单元格

(二)保存文件

设置单元格样式

(一)字体

(二)对齐方式

(三)边框

(四)设置行高和列宽

(五)合并和拆分单元格


openpyxl (Excel文件处理模块)

读sheet

读取Excel文件中的工作表(sheet)也是重要的知识点。在使用openpyxl库时,可以通过以下方式来读取工作表:

  1. 按名称读取工作表:你可以使用工作簿对象的sheetnames属性获取所有工作表的名称列表,然后通过工作簿对象的[sheet_name]或者get_sheet_by_name(sheet_name)方法来获取指定名称的工作表对象。
workbook = openpyxl.load_workbook('p1.xlsx')
sheet_names = workbook.sheetnames
sheet = workbook[sheet_names[0]]  # 根据名称获取第一个工作表对象
  1. 按索引读取工作表:除了按名称读取外,也可以直接使用索引来获取工作表对象。
workbook = openpyxl.load_workbook('p1.xlsx')
sheet = workbook.worksheets[0]  # 获取第一个工作表对象

一旦获取了工作表对象,我们就可以使用工作表对象进行单元格数据的读取,遍历行和列等操作。


实例

from openpyxl import load_workbookworkbook = load_workbook("p1.xlsx")# 1、获取excel文件中所有shell名称print(workbook.sheetnames)# 2、选择sheet,基础sheet名称
"""
sheet = workbook["人员"]
cell = sheet.cell(2,3)
print(cell.value)
"""# 3、选择sheet,基于索引位置
"""
sheet = workbook.worksheets[0] # worksheets 索引函数
cell = sheet.cell(2,3)
print(cell.value)
"""# 4、循环所有的sheet,三种方式!
"""
for name in workbook.sheetnames: # sheetnames 名称函数sheet = workbook[name]cell = sheet.cell(1,1)print(cell.value)""""""
for sheet in workbook.worksheets: # worksheets 索引函数cell = sheet.cell(1, 1)print(cell.value)
""""""
for sheet in workbook: cell = sheet.cell(1,1)print(cell.value)
"""

读sheet中单元格
from openpyxl import load_workbookwb = load_workbook("p1.xlsx")
sheet = wb.worksheets[0] # 获取索引位置为0的sheet --> 也就是第一个sheet
"""
# 1、获取第N行第N列的单元格(位置从1开始)
cell = sheet.cell(1,1)
print(cell.value) # 内容
print(cell.style) # 样式
print(cell.font)  # 字体
print(cell.alignment) # 排列情况
""""""
# 2、获取某个单元格
v1 = sheet["A2"]
print(v1.value)v2 = sheet["C2"]
print(v2.value)
"""# 3、获取第N行所有的单元格
"""
for cell in sheet[1]:print(cell.value)
"""# 4、获取所有行的数据
"""
for row in sheet.rows:print(row[0].value,row[1].value,row[2].value)
"""# 4、获取所有列的数据
"""
for clo in sheet.columns:print(clo[0].value,clo[1].value,clo[2].value)
"""

合并单元格
import openpyxl
from openpyxl import load_workbook# 打开excel工作表
workbook = openpyxl.load_workbook("p1.xlsx")# 获取所有工作表的名称列表
sheet_name = workbook.sheetnames# 选择第一个工作表进行操作
sheet = workbook[sheet_name[0]]# 合并A1:A2
sheet.merge_cells('A1:A2')# 设置合并后的值
sheet['A1'] = 'OK!'# 保存修改
workbook.save('p4.xlsx')

openpyxl模块基本用法

openpyxl 是一个用于处理 xlsx 格式 Excel 表格文件的第三方 python 库,其支持 Excel 表格绝大多数基本操作。

安装方法

使用 pip 或通过专门 python IDE(如pyCharm)进行安装

其中pip安装方法,命令行输入: pip install openpyxl

基本使用

第一步先是要导入 openpyxl 模块

import openpyxl

读取Excel文档

通过调用方法 load_workbook(filename) 进行文件读取,该方法中还有一个 read_only 参数用于设置文件打开方式,默认为可读可写,该方法最终将返回一个 workbook 的数据对象。

# 文件必须是xlsx格式,如果是其他格式在执行前可利用win32辅助转化
wb = openpyxl.load_workbook('p1.xlsx')

(一)获取工作表

每一个 Excel 表格中都会有很多张 sheet 工作表,在对表格操作前需要先选定一张工作表

# 获取所有工作表名(返回一个列表)
sheets = wb.get_sheet_names()# 获取某一特定的工作表
sheet = wb.get_sheet_by_name('Sheet2')# 获取工作表的表名
sheet_name = sheet.title# 一般来说,表格大多数用到的是打开时显示的工作表,这时可以用active来获取当前工作表
sheet = wb.active

(二)获取单元格

对 Excel 表格的操作最终都落于对单元格的操作,获取单元格有两种获取方法:sheet[列行名]和 sheet.cell(row,column)

# 通过sheet[列行名]获取
a = sheet['A2']# 通过sheet.cell(row,column)获取
b = sheet.cell(1, 2)  # 即sheet['B1']# 获取单元格内容
print(a.value)# 获取单元格所在列和行
print(‘a is ’+str((a.column,a.row)))

需要注意的是,sheet.cell(row,column)中参数分别是行和列,且必须为整数,如果列为英文字母,可以利用 openpyxl.utils 中的 column_index_from_string (char)进行字母数字的转化。顺便一说,同理也可以利用 get_column_letter(number) 进行数字字母间的转化

from openpyxl.utils import get_column_letter, column_index_from_string# 对列进行字母/数字转化
c_num = column_index_from_string('B')  # c_num = 2
c_char = get_column_letter(5)          # c_char = 'E‘

(三)获取行和列

在处理 Excel 表格有时可能需要对表格进行遍历查找,openpyxl 中便提供了一个行和列的生成器 (sheet.rows和sheet.columns) ,这两个生成器里面是每一行(或列)的数据,每一行(或列)又由一个 tuple 包裹,借此可以很方便地完成对行和列的遍历

# 对行进行遍历,输出A1,B1,C1
for row in sheet.rows:for cell in row:print(cell.value)# 对列进行遍历,输出A1,A2,A3
for column in sheet.columns:for cell in column:print(cell.value)

学习时还发现也可以通过 list(sheet.rows)index 对某一行或列进行遍历,而在此值得注意的是,由于sheet.rows(或sheet.columns)是生成器类型,是不能直接调用的,需将其转化为一个 list 类型,然后再通过索引遍历

# 对某一特定的行进行遍历
for cell in list(sheet.rows)[0]:print(cell.value)

同时,也可以通过使用 sheet[行列值:行列值] 来对给定单元格范围进行遍历

# 对某一单元格范围进行遍历
for spaces in sheet['A1':'B2']:for cell in spaces:print(cell.value)

另外,有时候我们还可能需要确定表格的大小,即获取表格行和列的最大值,可以用 max_rowmax_column 来获取

# 获得最大列和最大行
print(sheet.max_row)
print(sheet.max_column)

写入Excel文档

在开头读取时已经介绍,默认的打开方式为可读可写,那么使用 load_workbook(filename) 读取 Excel 文档后也就可以直接写入了。另外,如果需要新建一个 Excel 文件,可以使用 Workbook()方法,同时它会自动提供一个 sheet 工作表。对于删除一个工作表,则可以使用 workbook 对象的 remove(sheet) 方法删除

# 新建一个Excel文档
wb = openpyxl.Workbook()# 删除某个工作表 
wb.remove(sheet)

(一)写入单元格

获取工作表和之前一样,如果使用 load_workbook(filename) 读取,那么获取工作表后可以直接通过sheet[行列值]写入单元格。学习时,有资料介绍还可以传入Excel中的公式进行赋值,不过要注意,在读取文件时需要加上参数 data_only=True ,这样才能返回数字,否则将返回字符串,即公式本身。

# 直接赋值
sheet['A1'].value = 2# 公式赋值
sheet['A6'].value = '=SUM(A1:A5)'

另外,也可使用 sheet.append(parameters) 一行或多行写入

# 写入一行
row = [1 ,2, 3, 4, 5]
sheet.append(row)# 写入多行
rows = [['ID', 'Name', 'Department'],['001', 'Lee','CS'],['002', 'John','MA'],['003', 'Amy','IS']
]
sheet.append(rows)

(二)保存文件

写完文件后,使用 workbook.save(path+filename)进行保存,不过要注意文件扩展名一定要是 xlsx 格式

# 保存文件至当前目录
wb.save('new_file.xlsx')

设置单元格样式

单元格样式主要包括字体、边框、颜色以及对齐方式等,这些均位于 openpyxl.styles 库中

# 导入字体、边框、颜色以及对齐方式相关库
from openpyxl.styles import Font, Border, Side, PatternFill, colors, Alignment

(一)字体

通过 sheet 单元格 font 属性设置字体风格

# 设置字体风格为Times New Roman,大小为16,粗体、斜体,颜色蓝色
sheet['A1'].font = Font(name='Times New Roman', size=16, bold=True, italic=True, color=colors.BLUE)

(二)对齐方式

通过 sheet 单元格 alignment 属性设置文本对齐风格

# 通过参数horizontal和vertical来设置文字在单元格里的对齐方式,此外设置值还可为left和right
sheet['B1'].alignment = Alignment(horizontal='center',vertical='center')

(三)边框

通过 sheet 单元格 border 属性设置字体风格

# 首先设置边框四个方向的线条种类
left, right, top, bottom = [Side(style='thin', color='000000')] * 4
# 再将各方向线条作为参数传入Border方法
sheet['C1'].border = Border(left=left, right=right, top=top, bottom=bottom)

(四)设置行高和列宽

行和列的长度大小可以通过 row_dimensions[序号].height 和 column_dimensions[标号].width 来设置

# 设置行高
sheet.row_dimensions[1].height = 25# 设置列宽
sheet.column_dimensions['D'].width = 15.5

(五)合并和拆分单元格

对单元格的合并与拆分,主要是通过 sheet 的 merge_cells(args1:args2)和unmerge_cells(args1:args2) 两个方法来实现的;当然,除了对角矩形区域化合并,也可以对一行或一列进行合并,只需相应修改参数即可。不过,这里要注意的是,合并后单元格显示的文本内容是合并前最左上角单元格的内容,而其他单元格内容则会自动清除。

# 合并单元格
sheet.merge_cells('A1:B2')# 拆分单元格
sheet.unmerge_cells('A1:B2')

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

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

相关文章

git常用命令及仓库创建

git常用命令及仓库创建 Git介绍Git安装Gitee仓库初始化注册并激活码云账号生成本机SSH公钥配置SSH公钥创建空白仓库将本地项目上传到对应的空白仓库Git日常使用日常更新代码命令创建新仓库Git常用命令初始化本地Git仓库添加文件到暂存区本地提交更新查看当前仓库内容查看变更内…

东方博宜 1738. 胜负对决

东方博宜 1738. 胜负对决 以为这道题很简单呢,结果提交两次还不对,气死个人~ 思路:这道题的重点在于看清楚题意,是第奇数个,而不是数是奇数 。 还有,如果按照位数的奇偶来判定,那在读取数组的时…

UltraLight VM-UNet:平行视觉 Mamba 显着减少皮肤病变分割参数

UltraLight VM-UNet:平行视觉 Mamba 显着减少皮肤病变分割参数 摘要IntroductionRelated WorkMethodArchitecture OverviewMamba Parameter Impact AnalysisSkip-connection Path UltraLight VM-UNet: Parallel Vision MambaSignificantly Reduces Parameters for S…

文化力:潜力巨大的新质生产力与未来发展引擎

一、引言 在全球化浪潮的推动下,新质生产力正逐渐成为推动社会经济发展的核心动力。其中,文化力作为一种潜力巨大的新质生产力,正在逐渐展现出其独特的价值和影响力。文化经济化的开发不仅使文化赋能生产,更使文化赋能消费&#…

【考研数学】强化跟张宇还是武忠祥?看完这篇就明白了

SO,不管你是选择武忠祥老师还是张宇老师,学长学姐都可以拍着胸脯告诉你,这两位老师都很优秀,跟哪位老师都能学好,所以你也不用担心因为错过一位老师的课而错失整个天下啦~ 根据不同老师的特点,结合自身情况…

RN使用蓝牙扫描

我项目需要用到蓝牙模块,蓝牙扫描到设备并且获取到电量显示到页面上,因此我做了如下demo,使用了react-native-ble-plx这个插件 点击进入官方文档官方文档 1.安卓环境配置(ios暂定,还没做ios,不过下面的方法是兼容的,自行配置ios权限) android/app/src/main/AndroidManifest.xml…

[C++][算法基础]走迷宫(BFS)

给定一个 nm 的二维整数数组,用来表示一个迷宫,数组中只包含 0 或 1,其中 0 表示可以走的路,1 表示不可通过的墙壁。 最初,有一个人位于左上角 (1,1)(1,1) 处,已知该人每次可以向上、下、左、右任意一个方…

oracle全量、增量备份

采用0221222增量备份策略,7天一个轮回 也就是周日0级备份,周1 2 4 5 6 采用2级增量备份,周3采用1级增量备份 打开控制文件自动备份 CONFIGURE CONTROLFILE AUTOBACKUP ON; 配置控制文件备份路径 CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVI…

ChatGPT使用小结

ChatGPT是openAI旗下的一款语言模型,说它是语言模型更不如说他是一个全能小助手,自从去年它爆火之后,国内也出现了许多同款语言模型,这些智能语言模型的出现,对于像我这样的低端程序员的效率提升是巨大的。 很多人可能…

(二十七)Flask之数据库连接池DBUtils库

目录: 每篇前言:DBUtils库模式一(底层使用threading.local实现):模式二: Flask中使用方式一:直接将DBUtils初始化放到settings.py文件中方式二:从utils文件夹中导入 脚本使用DBUtils…

vue3+element+AntDesign(自动导入)+pina+vite+js+pnpm搭建项目框架

vue3elementAntDesign(自动导入)pinavitejspnpm搭建项目框架 文章目录 vue3elementAntDesign(自动导入)pinavitejspnpm搭建项目框架1. 安装pnpm:通过以下命令安装pnpm,它是一个快速、零配置的包管理工具。2. 初始化项目:在命令行中执行以下命…

python时间内存计算

记录python时间内存计算操作 时间计算采用time模块内存计算分别采用memory_profiler和psutil 1.占用时间计算:time import timedef funT(t):for i in range(t*10):passif __name____main__:t10begintime.time()funT(t)endtime.time()print(时间:{}s.for…

Qt plugin 开发UI界面插件

目录 1.创建接口 2.创建插件 3.创建插件界面 4.插件实现 5.创建应用工程 6.应用插件 1.创建接口 打开QtCreater,点击左上角“文件”->新建文件或项目,在弹窗中选择C/CHeader File。 输入文件名,选好路径(可自行设置名称…

jsonpath在线解析器网址

jsonpath在线解析器网址:https://jsonpath.com/

手动实现简易版RPC(上)

手动实现简易版RPC(上) 前言 什么是RPC?它的原理是什么?它有什么特点?如果让你实现一个RPC框架,你会如何是实现?带着这些问题,开始今天的学习。 本文主要介绍RPC概述以及一些关于RPC的知识,为…

02-结构化程式与自定义函数

视频教程:b站视频【MATLAB教程_台大郭彦甫(14课)原视频补档】https://www.bilibili.com/video/BV1GJ41137UH/?share_sourcecopy_web&vd_sourc*ed6b9f96888e9c85118cb40c164875dfc 官网教程: MATLAB 快速入门 - MathWorks 中…

【动手学深度学习】15_汉诺塔问题

注: 本系列仅为个人学习笔记,学习内容为《算法小讲堂》(视频传送门),通俗易懂适合编程入门小白,需要具备python语言基础,本人小白,如内容有误感谢您的批评指正 汉诺塔(To…

基于springboot实现高校学科竞赛平台系统项目【项目源码+论文说明】

基于springboot实现高校学科竞赛平台系统演示 摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了高校学科竞赛平台的开发全过程。通过分析高校学科竞赛平台管理的不足,创建了一个计算机管理高校学科竞…

day02 51单片机

51单片机学习 1闪烁LED 1.1 需求描述 这个案例,我们要让P00引脚对应的LED按照1秒闪烁1次。 1.2 硬件设计 1.1 软件设计 1)LED闪烁的代码 想让LED闪烁,就需要P00的值不断在0和1之间循环变化。实现这一功能的代码也很简单: #include <STC89C5xRC.H> //包含STC89…

超详细的 Python 文件操作知识!

python进行文件操作&#xff0c;在日常编程中是很常用的。为了方便大家&#xff0c;这里对各种文件操作的知识进行汇总。一文在手&#xff0c;无须它求&#xff01;来一起学习吧。 一、文件的打开和关闭 open()函数 f1 open(rd:\测试文件.txt, moder, encodingutf-8) conte…