python 使用 openpyxl 处理 Excel 教程

news2024/12/26 6:39:25

目录

  • 前言
  • 一、安装openpyxl库
  • 二、新建excel及写入单元格
    • 1.创建一个xlsx格式的excel文件并保存
    • 2.保存成流(stream)
    • 3.写入单元格
  • 三、创建sheet工作表及操作
  • 四、读取excel和单元格
    • 1.读取 excel 文件
    • 2.读取单元格
    • 3.获取某一行某一列的数据
    • 4.遍历所有单元格
    • 5.遍历指定行列范围的单元格
  • 五、合并、拆分单元格和插入删除行列
    • 1.合并单元格
    • 2.拆分合并的单元格
    • 3.插入行和列
      • (1)插入单行单列
      • (2)插入多行多列
    • 4.删除行和列
      • (1)删除单行单列
      • (2)删除多行多列
  • 六、单元格对齐
    • 1. 对齐方式与换行
    • 2.单元格对齐
    • 3.合并后的单元格设置对齐方式
  • 七、单元格边框设置
    • 1. 边框线条粗细、颜色设置
    • 2.设置单个单元格边框和颜色
    • 3.设置多个单元格整体边框和颜色
  • 八、设置单元格背景颜色和文字字体
    • 1.设置单元格背景颜色
    • 2.设置字体、字体的粗细、大小、颜色
  • 九、设置行高和列宽

前言

python 操作excel 的库有很多 ,有的库只能读取 xsl 格式,比如 xlrd 库;
有的库只能写 xsl 格式,比如 xlwt 库;
有的只能读写 xslx 格式,比如 openpyxl 库 。

综合各库及 xslx 格式比较常见,所以本文主要讲解 openpyxl 库对 xslx 格式的 excel 操作。

一、安装openpyxl库

pip install openpyxl

二、新建excel及写入单元格

1.创建一个xlsx格式的excel文件并保存

from openpyxl import Workbook

# 创建一个工作表
wb = Workbook()
# 保存为本地excel文件
wb.save("F:\pythonTest\sample.xlsx")

2.保存成流(stream)

例如当使用 Pyramid, Flask 或 Django 等 web 应用程序时,如果想把文件保存成流,可以使用 NamedTemporaryFile( )方法

from tempfile import NamedTemporaryFile
from openpyxl import Workbook

wb = Workbook()
with NamedTemporaryFile() as tmp:
     wb.save(tmp.name)
     tmp.seek(0)
     stream = tmp.read()

3.写入单元格

from openpyxl import Workbook

wb = Workbook()
# 创建第一个sheet
sheet = wb.active

# 方式一 在第1行第1列的单元格写入111
sheet['A1'] = 111
# 方式二 在第1行第1列的单元格写入111
# sheet.cell(row=1, column=1, value=111)
# 方式三 先获取到单元格,再将数据写入value属性
# cell = sheet['A1']
# cell.value = 111

wb.save("F:\pythonTest\sample.xlsx")

下面的简单示例将新建一个 xlsx 文件并在里面新建 3 个 sheet 工作表,每个 sheet 工作表都写上一点数据:

from openpyxl import Workbook

# 初始化
wb = Workbook()

# 创建第一个sheet
sheet = wb.active
# 在第1行第1列的单元格写入111
sheet['A1'] = 111

# 创建一个新的sheet
sheet1 = wb.create_sheet()
# 在这个新的sheet中第2行第2列的单元格写入222
sheet1['B2'] = 222

# 创建一个叫"第3个工作表"的新sheet
sheet3 = wb.create_sheet("第3个工作表")
# 在这个新的sheet中第3行第3列的单元格写入333
sheet3['C3'] = 333

# 保存本地excel文件中
wb.save("F:\pythonTest\sample.xlsx")

请添加图片描述

三、创建sheet工作表及操作

1.创建新的工作表

一个工作表至少有一个工作表,你可以通过 Workbook.active 来创建第一个sheet

sheet = wb.active

创建新的带有名字的工作表

# 在结尾插入一个叫 "我的sheet1" 的sheet
sheet1 = wb.create_sheet("我的sheet1") 
# 或者在最开始插入一个叫 "我的sheet12" 的sheet
sheet2 = wb.create_sheet("我的sheet12", 0)
# 或者在倒数第二的位置插入一个叫 "我的sheet13" 的sheet
sheet3 = wb.create_sheet("我的sheet13", -1) 

2.删除指定工作表

# 删除名字是 "我的sheet13" 的工作表
wb.remove(wb['3号sheet'])

3.修改sheet工作表的名称

# 在结尾插入一个叫 "我的sheet1" 的工作表
sheet1 = wb.create_sheet("我的sheet1") 
# 将"我的sheet1" 的工作表名字改为"first"
sheet1.title = "first"

4.获取所有工作表的名称

print(wb.sheetnames) #['Sheet', '我的sheet1', 'first', 'second']

5.切换工作表

current = wb["first"]
# 切换到 "second" 工作表
current = wb["second"]

6.遍历所有sheet工作表

for s in wb:
     print(s.title)

7.复制sheet工作表

sheet = wb.active
sheetNew = wb.copy_worksheet(sheet)

四、读取excel和单元格

1.读取 excel 文件

读取 excel 文件并打印所有的 sheet 工作表名称

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
print(wb.sheetnames) # ['Sheet', 'Sheet1', 'New Title']

2.读取单元格

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取"New Title" 这个sheet工作表
sheet = wb["第3个工作表"]

# 方式一 获取 "C3"这个单元格
cell = sheet["C3"]
# 方式二 获取 第3行3列 这个单元格
# cell = sheet.cell(row=3, column=3)

# 打印单元格的值
print(cell.value)

3.获取某一行某一列的数据

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample1.xlsx")
sheet = wb["Sheet"]

# 获取第2行的单元格数据并打印
row = sheet['2']
row_data = []
for cell in row:
    row_data.append(cell.value)
print(row_data)

# 获取第3列的单元格数据并打印
col = sheet['C']
col_data = []
for cell in col:
    col_data.append(cell.value)
print(col_data)


4.遍历所有单元格

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 遍历所有的sheet工作表
for sheet in wb:
    # 获取当前sheet工作表的行数据
    rows = tuple(sheet.rows)
    # 遍历每一行
    for row in rows:
        # 遍历每一个单元格
        for cell in row:
            print(cell.value)

上面使用了sheet.rows 获取行数据,如果要获取列数据可以使用 sheet.columns

5.遍历指定行列范围的单元格

方式一:使用切片方式

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取叫"Sheet"的工作表
sheet = wb["Sheet"]
# 获取叫'A2'到'C4'范围的所有单元格
rows = sheet['A2':'C4']
for cells in rows:
    for cell in cells:
        print(cell.value, end=" ")
    print()

方式二:使用iter_rows方法

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取叫"Sheet"的工作表
sheet = wb["Sheet"]
# 获取 2到4行,1到3列 范围的所有单元格
for row in sheet.iter_rows(min_row=2, min_col=1, max_col=3, max_row=4):
    for cell in row:
        print(cell.value, end=" ")
    print()

五、合并、拆分单元格和插入删除行列

1.合并单元格

合并单元格时,除了左上角的单元格内容,其他都选中范围单元格将从工作表中删除

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取叫"Sheet"的工作表
sheet = wb["Sheet"]

# 方式一 合并 A2到C4 范围的单元格
sheet.merge_cells('A2:C4')
# 方式二 合并 2到4行,1到3列 范围的所有单元格
# sheet.merge_cells(start_row=2, start_column=1, end_row=4, end_column=3)

wb.save("F:\pythonTest\sample.xlsx")

在这里插入图片描述

2.拆分合并的单元格

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取叫"Sheet"的工作表
sheet = wb["Sheet"]

# 方式一 拆分 A2到C4 范围的单元格
sheet.unmerge_cells('A2:C4')
# 方式二 拆分 2到4行,1到3列 范围的所有单元格
ws.unmerge_cells(start_row=2, start_column=1, end_row=4, end_column=4)

wb.save("F:\pythonTest\sample.xlsx")

3.插入行和列

(1)插入单行单列

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
sheet = wb["Sheet"]
# 在第3行前插入一行
sheet.insert_rows(3)
# 在第2列前插入一列
sheet.insert_cols(2)
wb.save("F:\pythonTest\sample.xlsx")

(2)插入多行多列

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
sheet = wb["Sheet"]
# 在第3行前插入四行
sheet.insert_rows(3, 4)
# 在第2列前插入五列
sheet.insert_cols(2, 5)
wb.save("F:\pythonTest\sample.xlsx")

4.删除行和列

(1)删除单行单列

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
sheet = wb["Sheet"]
# 删除第3行
sheet.delete_rows(3)
# 删除第2列
sheet.delete_cols(2)
wb.save("F:\pythonTest\sample.xlsx")

(2)删除多行多列

from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
sheet = wb["Sheet"]
# 从第3行前开始删除四行
sheet.delete_rows(3, 4)
# 从第2列开始删除五列
sheet.delete_cols(2, 5)
wb.save("F:\pythonTest\sample.xlsx")

六、单元格对齐

1. 对齐方式与换行

# horizontal是水平方向,vertical 是垂直方向
Alignment(horizontal="center", vertical="center")
# 默认单元格填满了是不换行的,如果要自动换行可使用 wrap_text=True
Alignment(horizontal="center", vertical="center", wrap_text=True)

horizontal 水平对齐可选值如下

参数值对齐方式
left左对齐
center左右居中
right右对齐
fill填满对齐
distributed分散对齐
centerContinously连续居中
justify两端对齐
general一般对齐

vertical 垂直对齐可选值如下

参数值对齐方式
top上对齐
center左右居中
bottom下对齐
distributed分散对齐
justify两端对齐

2.单元格对齐

from openpyxl import Workbook
from openpyxl.styles import Alignment

wb = Workbook()
sheet = wb.active

# 在第1行第1列的那个单元格写入123546
cell = sheet['A1']
cell.value = 123546
# 将该单元格对齐方式设置为水平和垂直都居中
cell.alignment = Alignment(horizontal="center", vertical="center")

wb.save("F:\pythonTest\sample.xlsx")

3.合并后的单元格设置对齐方式

可以改变左上单元格的对齐方式、边框等属性来改变整个合并单元格的对齐方式、边框等属性。

from openpyxl.styles import Alignment
from openpyxl import load_workbook

wb = load_workbook("F:\pythonTest\sample.xlsx")
# 获取叫"Sheet"的工作表
sheet = wb["Sheet"]

#  合并 A2到C4 范围的单元格
sheet.merge_cells('A2:C4')
# 改变左上单元格的对齐方式来改变合并单元格的对齐方式
cell = sheet['A2']
cell.alignment = Alignment(horizontal="center", vertical="center")

wb.save("F:\pythonTest\sample.xlsx")

七、单元格边框设置

1. 边框线条粗细、颜色设置

(1)你可以对单元格上下左右的边框进行设置虚线和实线

Border(
    left=Side(style='thick'),
    bottom=Side(style='mediumDashed'),
    right=Side(style='thin'),
    top=Side(style='dashed'))

其中thin是细实线,thick是粗实线,dashed是细虚线,mediumDashed是粗虚线.
全部边框线条可选的有如下:

'dashDot','dashDotDot', 'dashed','dotted',
'double','hair', 'medium', 'mediumDashDot', 
'mediumDashDotDot','mediumDashed', 'slantDashDot',
'thick', 'thin'

(2)你还可以使用 color 参数调整单元格上下左右边框的颜色

Border(
    left=Side(style='thick', color='00000000'),
    bottom=Side(style='mediumDashed', color='00000000'),
    right=Side(style='thin', color='00000000'),
    top=Side(style='dashed', color='00000000'))

可取的颜色参考如下:

请添加图片描述

2.设置单个单元格边框和颜色

from openpyxl import Workbook
from openpyxl.styles import Border, Side

wb = Workbook()
sheet = wb.active

# 在第1行第1列的那个单元格写入123546
cell = sheet['B2']
cell.value = 123546
# 设置该单元格边框和颜色
cell.border = Border(
    left=Side(style='thick', color='00000000'),
    bottom=Side(style='mediumDashed', color='00000000'),
    right=Side(style='thin', color='00000000'),
    top=Side(style='dashed', color='00000000'))

wb.save("F:\pythonTest\sample1.xlsx")

3.设置多个单元格整体边框和颜色

想要整体添加边框,有两种方式:

(1) 先合并单元格再对左上角的单元格进行操作,但往往这些单元格都有不同的数据,难以进行合并。
(2) 遍历所有的单元格,分别赋予属性。这种方法比较适用于为所有的单元格赋予相同的属性。

八、设置单元格背景颜色和文字字体

1.设置单元格背景颜色

from openpyxl import Workbook
from openpyxl.styles import PatternFill

wb = Workbook()
sheet = wb.active

# 在第1行第1列的那个单元格写入123546
cell = sheet['B2']
cell.value = 123546
# 使用fgColor属性16进制颜色填充
cell.fill = PatternFill('solid', fgColor="FF00FF")

wb.save("F:\pythonTest\sample1.xlsx")

2.设置字体、字体的粗细、大小、颜色

from openpyxl import Workbook
from openpyxl.styles import Font

wb = Workbook()
sheet = wb.active

# 在第1行第1列的那个单元格写入123546
cell = sheet['B2']
cell.value = 123546
# 设置字体样式:  字体大小为30, bold加粗,字体颜色 00FFFF 16进制颜色
cell.font = Font(u'微软雅黑', size=30, bold=True, color="00FFFF")

wb.save("F:\pythonTest\sample1.xlsx")

九、设置行高和列宽

from openpyxl import Workbook

wb = Workbook()
sheet = wb.active

# 设置第1行高度为60
sheet.row_dimensions[1].height = 60
# 设置B列宽度为30
sheet.column_dimensions["B"].width = 30

wb.save("F:\pythonTest\sample1.xlsx")

参考:
Tutorial

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

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

相关文章

Android卡顿优化

卡顿的定义 如果在一个Vsync周期内(60HZ的屏幕上就是16.6ms),按照整个上帧显示的执行的顺序来看,应用UI线程的绘制、RenderThread线程的渲染、SurfaceFlinger/HWC的图层合成以及最终屏幕上的显示这些动作没有全部都执行完成的话&…

【C语言】-- X型图案

今天刷了牛客网上的一道题,不难,但思路很重要,否则你就得写一长串代码,下面是要求。牛客网链接->X形图案。 下面是两组示例。 通过观察示例,我们发现输入的数字是奇数时,图案最中间只有一个*&#xff0c…

什么是Ajax?Ajax如何发送请求(详)

本篇来讲关于Ajax的内容,当然还有小伙伴可能不知道该怎么读 "Ajax",它读 "阿贾克斯" ,当然了读法可能因人而异,下面来进入正题,先来了解一下什么是Ajax? Ajax 是什么? Ajax…

魔法与现实-如何使用GPT帮我改一个万行vue代码中的BUG

开篇 传说在人类诞生之初是和魔法共存的。随时时间的流失,人们逐步开始淡忘了魔法。也有传说魔法是亚瑟王于“剑栏“一战(Battle of Camlann)后梅林永远封存了魔法使其不被心术不正者所使用。不管哪种说法,随着时间的流失,人类在飞速进步。从水利磨坊到蒸汽机的发明、再到…

Latex中表格Table环境和Tabular环境

目录 一、Table和Tabular的区别 二、一个简单的Table环境示例: 三、Latex的“自动换行”功能 四、Latex多行和多列 五、使用tablesgenerator快速将excel表格转换成tex代码 六、设置表格的宽度与页面宽度一致 说明:一至四内容来自Latex中使用Table(表…

Scala入门【运算符和流程控制】

运算符 在 Scala 中其实是没有运算符的,所有运算符都是方法。我们只是省去了 .方法名() 中的点 . 和括号 () 。 调用对象的方法时,点 . 可以省略;如果函数参数只有一个,或者没有参数,括号()可以省略。 //num1 n…

Unity解决:GIS(GPS的经纬度坐标)定位系统坐标转unity坐标(世界坐标)

目录 一、前言 二、功能实现 三、测试 四、备注 如果要实现该效果的demo,请联系作者 一、前言 最近项目中用到了第三方的定位系统,有的是使用GPS定位、有的是使用UWB定位。第三方的定位系统把他们的定位信息通过网络发送给Unity,在Unity…

项目集活动—项目集定义阶段活动

项目集活动是为支持项目集而开展的任务和工作,贯穿整个项目集生命周期。 项目集活动包括: 项目集定义阶段活动 项目集交付阶段活动项目集收尾阶段活动 鉴于项目集的范围和复杂性,在整个项目集生命周期中,将执行许多项目集支持活…

走向CV的通用人工智能:从GPT和大型语言模型中汲取的经验教训 (上)

点击蓝字 关注我们 关注并星标 从此不迷路 计算机视觉研究院 公众号ID|计算机视觉研究院 学习群|扫码在主页获取加入方式 论文地址:https://arxiv.org/pdf/2306.08641.pdf 计算机视觉研究院专栏 Column of Computer Vision Institute 人工智能…

交织技术详解

本专栏包含信息论与编码的核心知识,按知识点组织,可作为教学或学习的参考。markdown版本已归档至【Github仓库:https://github.com/timerring/information-theory 】或者公众号【AIShareLab】回复 信息论 获取。 文章目录 交织技术1.突发错误…

Linux系统:ulimit命令

目录 一、理论 1.ulimit命令 二、实验 1.打开的最大文件描述符的数量为65535 一、理论 1.ulimit命令 (1)概念 ulimit是一个计算机命令,用于shell启动进程所占用的资源,可用于修改系统资源限制,限制每个用户可使用…

资源有限的大型语言模型的全参数微调

文章目录 摘要1、简介2、相关工作3、方法3.1、重新思考optimizer的功能3.1.1、使用SGD3.1.2、隐式BatchSize 3.2、LOMO:低内存优化3.3、使用LOMO稳定训练3.3.1、梯度归一化和裁剪的替代方法3.3.2、缓解精度下降 4、实验4.1、内存配置4.2、吞吐量4.3、下游性能4.3.1、主要结果4.…

复杂的HANASQL 多行并入一行

点击蓝字 关注我们 一 前言 基于HANA的内存数据库的强大性能, SAP建议把业务逻辑下沉到HANA中计算.以便减去应用服务器的负担,让程序性能更好一些. SAP本身的一些复杂的业务逻辑比如MRP运算(MD01)也有了新的事务 MD01N (MRP LIVE) 报表类的数据分析程序尤其适用. 动态报表强化了…

PromptBench:大型语言模型的对抗性基准测试

PromptBench是微软研究人员设计的一个用于测量大型语言模型(llm)对对抗性提示鲁棒性的基准测试。这个的工具是理解LLM的重要一步,随着这些模型在各种应用中越来越普遍,这个主题也变得越来越重要。 研究及其方法论 PromptBench采用多种对抗性文本攻击&am…

阿里云服务器的存储容量和性能如何?是否支持多种存储类型?

阿里云服务器的存储容量和性能如何?是否支持多种存储类型?   本文由阿里云代理商[聚搜云]撰写   阿里云服务器作为业界领先的云计算服务提供商,其存储容量和性能一直受到广泛关注。本文将为您介绍阿里云服务器的存储容量、性能以及支持的…

《斯坦福数据挖掘教程·第三版》读书笔记(英文版)Chapter 12 Large-Scale Machine Learning

来源:《斯坦福数据挖掘教程第三版》对应的公开英文书和PPT Chapter 12 Large-Scale Machine Learning Algorithms called “machine learning” not only summarize our data; they are perceived as learning a model or classifier from the data, and thus dis…

Spring Boot 如何使用 @RequestParam 进行数据校验

Spring Boot 如何使用 RequestParam 进行数据校验 在 Web 应用程序中,用户提交的数据通常以请求参数的形式传递。在 Spring Boot 中,可以使用 RequestParam 注解来获取请求参数。但是,如何确保这些请求参数的有效性呢?在本文中&a…

Webots介绍

Webots介绍 1 介绍1.1 概述1.2 应用1.3 入门要求1.4 技术支持1.5 仿真步骤世界(webots定义)控制器超级控制器 1.6 平台能力三维建模能力物理引擎外设支持 2 软件使用启动webots用户界面文件菜单编辑菜单查看菜单模拟菜单构建菜单叠加菜单工具菜单帮助菜单…

ROS:文件系统以及命令

目录 一、ROS文件系统二、package.xml三、CMakelists.txt四、ROS文件系统命令4.1增4.2删4.3查4.4改4.5roscode4.6rosrun4.7roslaunch 一、ROS文件系统 ROS文件系统级指的是在硬盘上ROS源代码的组织形式,其结构大致如下图所示: WorkSpace --- 自定义的…

在DailyMart中是如何支持多种登录方式的?

欢迎回来,我是飘渺。今天继续更新DDD&微服务的系列文章。 1. 理解DDD中的领域模型职责 在我们开始今天的主题之前,让我们先回答一些读者的疑问。 在上一篇文章 [[DailyMart05:通过用户注册呈现一个完整的DDD开发流程]] 发布以后&#xf…