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

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方法示例

工作簿操作

创建工作簿:

wb = openpyxl.Workbook()

获取活动表:

active_sheet = wb.active 

创建新表:

new_sheet = wb.create_sheet('New Sheet')

获取所有表名:

sheets = wb.sheetnames

切换活动表:

wb.active = wb['Sheet1']

工作表操作

选择表:

ws = wb['Sheet1']

获取最大行数:

max_row = ws.max_row 

获取最大列数:

max_col = ws.max_column

获取单元格:

cell = ws.cell(row=1, column=1)

获取行:

row = ws[1] 

获取列:

col = ws['A']

append行:

ws.append([1, 2, 3])

单元格操作

赋值:

cell.value = 'Hello'

转换数据类型:

cell.number_format = 'yyyy-mm-dd'

设置样式:

cell.font = Font(color='00FF0000')

合并单元格:

ws.merge_cells('A1:B3')

调整列宽:

ws.column_dimensions['B'].width = 30

工作簿操作

保存:

wb.save('example.xlsx')  

加载:

wb = openpyxl.load_workbook('example.xlsx')

例子

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

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中创建简单工作簿和工作表的示例:

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文件。

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

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

相关文章

使用 FastGPT 构建高质量 AI 知识库

作者:余金隆。FastGPT 项目作者,Sealos 项目前端负责人,前 Shopee 前端开发工程师 FastGPT 项目地址:https://github.com/labring/FastGPT/ 引言 自从去年 12 月 ChatGPT 发布以来,带动了一轮新的交互应用革命。尤其在…

GPT Prompt编写的艺术:如何提高AI模型的表现力

随着AI技术的迅速发展,人工智能模型变得越来越强大,能够协助我们完成各种任务。然而,如何更好地利用AI的能力仍然存在很大的探索空间。在与AI进行交互的过程中,我们主要依赖于Prompt,不管是直接与大模型交互&#xff0…

layui之layer弹出层的icon数字及效果展示

layer的icon样式 icon如果在信息提示弹出层值(type为0)可以传入0-6,icon与图标对应关系如下: 如果是加载层(type为3)可以传入0-2,icon与图标对应关系如下:

Java中运算符要注意的一些点

目录 1. 算术运算符 1. 1 基本四则运算符:加减乘除模( - * / %) 1.2. 增量运算符 - * % 2. 关系运算符 3. 逻辑运算符 3.1. 逻辑与 && 3.2. 逻辑 || 3.3. 逻辑非 ! 3.4. 短路求值 4. 位运算符 4.1. 按位与 &: 如果两个二进制位都是 …

骨传导耳机什么牌子好?盘点最受欢迎的几款骨传导耳机

骨传导耳机最近一两年越来越受欢迎,市场上不同形态的非入耳式耳机都有,从骨传导,夹耳式到气传导等等都有。骨传导耳机的好处有很多,非入耳式,不伤耳朵,佩戴更舒适更安全。但是一直以来,骨传导耳…

Effective Java笔记(25)限制源文件为单个顶级类

虽然 Java 编译器允许在一个源文件中定义多个顶级类,但这么做并没有什么好处,只会带来巨大的风险 。 因为在一个源文件中定义多个顶级类,可能导致给一个类提供多个定义 。 哪一个定义会被用到,取决于源文件被传给编译器的顺序 。 …

Linux系统中/boot和swap分区的作用

Linux系统中/boot和swap分区的作用 /boot和swap分区的作用为什么虚拟机不要swap /boot和swap分区的作用 /boot分区是Linux系统中的一个特定分区,它用于存放引导加载程序和内核镜像等启动所需的文件。当计算机启动时,BIOS或UEFI会加载/boot分区上的引导加…

【2023年电赛】运动目标控制与自动追踪系统(E 题)最简单实现

本方案的思路是最简单的不涉及复杂算法:识别矩形框,标记矩形框,输出坐标和中心点,计算长度,控制舵机移动固定长度!仅供完成基础功能参考,不喜勿喷! # 实现运动目标控制与自动追踪系…

租赁类小程序定制开发|租赁管理系统源码|免押租赁系统开发

随着互联网的发展,小程序成为了一种重要的移动应用开发方式。租赁小程序作为其中的一种类型,可以为很多行业提供便利和创新。下面我们将介绍一些适合开发租赁小程序的行业。   房屋租赁行业:租房小程序可以帮助房东和租户快速找到合适的租赁…

D中国粉尘过滤器行业竞争战略规划与投资前景策略研究报告2023-2029年

D中国粉尘过滤器行业竞争战略规划与投资前景策略研究报告2023-2029年 ################################### 《报告编号》: BG460706 《出版时间》: 2023年8月 《出版机构》: 中智正业研究院 《交付方式》: EMIL电子版或特快专递 免费售后 服务一年,具体内容及…

Vue2 第十七节 Vue中的Ajax

1.Vue脚手架配置代理 2.vue-resource 一.Vue脚手架配置代理 1.1 使用Ajax库 -- axios ① 安装 : npm i axios ② 引入: import axios from axios ③ 使用示例 1.2 解决开发环境Ajax跨域问题 跨域:违背了同源策略,同源策略规定协议名&#xff0…

idea-常用插件汇总

idea-常用插件汇总 码云插件 这个插件是码云提供的ps-码云是国内的一款类似github的代码托管工具。 Lombok Lombok是一个通用Java类库,能自动插入编辑器并构建工具,简化Java开发。通过添加注解的方式,不需要为类编写getter或setter等方法…

Java源码规则引擎:jvs-rules 8月新增功能介绍

JVS-rules是JAVA语言下开发的规则引擎,是jvs企业级数字化解决方案中的重要配置化工具,核心解决业务判断的配置化,常见的使用场景:金融信贷风控判断、商品优惠折扣计算、对员工考核评分等各种变化的规则判断情景。 8月是收获的季节…

7种有效安全的网页抓取方法,如何避免被禁止?

网页抓取是一种从互联网上抓取网页内容的过程,但在网络抓取种相信您也经常遇到障碍?尤其是做跨境业务的,在抓取国外的网站时更有难度。但我们站在您的立场上,提供七种有效的方法来进行网页抓取而不被阻止,最大限度地降…

js调用栈分析

s调用栈 执行上下文:执行上下文就是当前js代码被解析和执行所在环境的抽象的概念(执行环境) js中的任何代码都是在执行上下文中执行的 js的执行环境:JS代码运行起来,执行上下文 js的执行上下文分为三种&#xff1a…

windows安装kafka配置SASL-PLAIN安全认证

目录 1.Windows安装zookeeper: 1.1下载zookeeper 1.2 解压之后如图二 1.3创建日志文件 1.4复制 “zoo_sample.cfg” 文件 1.5更改 “zoo.cfg” 配置 1.6新建zk_server_jaas.conf 1.7修改zkEnv.cmd 1.8导入相关jar 1.9以上配置就配好啦,接下来启…

Atcoder 做题记录

My OI Blog A R C 155 F \mathbb{ARC \ 155 \ F} ARC 155 F E, F 先咕着,做一些多项式题,这篇题解是我人工翻译的 [1] Double Counting 双重计数 考虑从叶子节点开始,用唯一的方式(如果有的话)来构造出一棵满足条件的树…

“AI乳腺癌检测”风暴眼中的三篇论文

深度学习和医学研究界对谷歌、纽约大学和DeepHealth发表的三篇有前途的乳腺癌诊断论文引发的讨论非常热烈。 几年前,纽约大学的一组研究人员开始发表关于将深度学习应用于癌症筛查的论文。该团队的最新论文《深度神经网络改善放射科医生在癌症筛查中的表现》于2019…

mybatisplus集成geometry实现增改功能

前言 在我们工作中想要实现将空间点位信息存储到数据库时,一般使用以下语句实现 INSERT INTO test-point ( point,text ) VALUES ( st_GeomFromText ( POINT(1 1) ),第1个点);update test-point set pointst_PointFromText(POINT(5 5)) where id 10;但是这样每次都要去编写新…

【腾讯云 Cloud Studio 实战训练营】使用Cloud Studio快速构建React完成点餐H5页面还原

文章目录 一、前言二、Cloud Studio 功能介绍三、实验介绍四、实操指导打开官网注册 Cloud Studio 五、开发一个简版的点餐系统安装 antd-mobile安装 Less 六、发布仓库七、开发空间八、总结 一、前言 IDE(集成开发环境)是一种软件工具,旨在…