Python 操作 读/写 Excel

Python 操作 读/写 Excel

准备知识

文件格式

什么是 xls
格式类型XLS 是 Excel 97-2003 使用的文件格式,基于二进制文件格式
文件扩展名.xls
兼容性由于其历史悠久,XLS 文件格式在较旧版本的 Excel 中广泛使用。较新的 Excel 版本也能打开和编辑 XLS 文件
特性和限制最大支持 65536 行和 256 列。
因为是二进制格式,文件较大,处理速度较慢。
支持的功能和特性相对较少,不支持一些新功能。
什么是 xlsx
格式类型XLSX 是 Excel 2007 及之后版本使用的文件格式,基于 Office Open XML 标准(XML 文件格式)。
文件扩展名.xlsx
兼容性XLSX 是现代 Excel 版本默认使用的文件格式
特性和优势最大支持 1048576 行和 16384 列
由于基于 XML,文件压缩更好,体积更小,处理速度更快。
支持更多新功能和特性,如更复杂的图表、条件格式、数据验证等。
更安全,支持更好的数据恢复机制
什么是 XLSM
格式类型XLSM 是 Excel 2007 及之后版本使用的文件格式,基于 Office Open XML 标准(XML 文件格式)
文件扩展名.xlsm
兼容性XLSM 文件与现代版本的 Excel 兼容
特性和优势支持宏
XLSM 文件可以存储和执行 VBA 宏,适用于需要自动化任务的复杂工作簿。
结构和功能
与 XLSX 文件类似,XLSM 也基于 XML 格式,支持更大容量的数据存储(最大支持 1048576 行和 16384 列)和丰富的功能特性(如复杂图表、条件格式、数据验证等)。
安全性
由于宏可以执行代码,XLSM 文件可能带有安全风险。Excel 会在打开 XLSM 文件时提示用户启用或禁用宏,以防止潜在的恶意代码执行。
使用场景自动化任务:在 Excel 中自动化重复性任务,如数据处理、报表生成等。
复杂工作簿:包含大量数据和复杂功能的工作簿,特别是需要宏来提高效率的场景。
注意事项安全风险:由于宏可以包含恶意代码,打开不明来源的 XLSM 文件时要谨慎,确保文件来自可信来源。
启用宏:Excel 默认会禁用宏,需要手动启用以运行宏功能。

术语

工作表工作薄

工作表

工作表: xlsx 文件

openpyxl

openpyxl 是一个用于读取和写入 Excel 2010 xlsx/xlsm/xltx/xltm 文件的 Python 库。它支持 Excel 文件的创建、修改和数据提取,并能处理复杂的电子表格操作,如公式、图表和格式设置。openpyxl 以其易用性和强大功能广受欢迎,适用于数据分析、自动化报表生成等任务。

安装

pip install openpyxl

Example 1 - 创建表格

将以下数据写入工作表

要求如下:

工作表名 example1.xlsx

工作薄名 大数据1班

学号姓名性别年龄
21001张三18
21002李四20

代码实现

from openpyxl import Workbook# 创建工作表
work_book = Workbook()# print(work_book.sheetnames)
# ['Sheet']# 一个工作表至少有一个工作簿. 你可以通过 Workbook.active 来获取
work_sheet = work_book.active# 修改工作薄的名字
work_sheet.title = "大数据1班"# 将数据写入单元格
work_sheet.cell(row=1, column=1, value="学号")
work_sheet.cell(row=1, column=2, value="姓名")
work_sheet.cell(row=1, column=3, value="性别")
work_sheet.cell(row=1, column=4, value="年龄")work_sheet.cell(row=2, column=1, value="21001")
work_sheet.cell(row=2, column=2, value="张三")
work_sheet.cell(row=2, column=3, value="男")
work_sheet.cell(row=2, column=4, value=18)work_sheet.cell(row=3, column=1, value="21002")
work_sheet.cell(row=3, column=2, value="李四")
work_sheet.cell(row=3, column=3, value="女")
work_sheet.cell(row=3, column=4, value=20)# 保存工作表
work_book.save("./example1.xlsx")

Example 2 - 读取表格数据

from openpyxl.reader.excel import load_workbookoperate_file = "./files/example1.xlsx"
new_operate_file = "./files/example2.xlsx"
# 打开工作表
work_book = load_workbook(operate_file)# print(work_book.sheetnames)
# ['大数据1班']# 获取工作薄
work_sheet = work_book["大数据1班"]# 获取单元格数据
# 比如获取 第二行, 第四列 的数据
d = work_sheet.cell(row=2, column=4)
print(d.value)# 修改单元格数据
work_sheet.cell(row=2, column=4, value=28)# 假如修改了单元格的数据, 应该保存到文件# 保存方式1:  保存到原文件
# work_book.save(operate_file)# 保存方式2:  保存到新文件
work_book.save(new_operate_file)

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

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

相关文章

Android平台RTSP|RTMP播放器高效率如何回调YUV或RGB数据?

技术背景 我们在做Android平台RTSP、RTMP播放器的时候,经常遇到这样的技术诉求,开发者希望拿到播放器解码后的YUV或RGB数据,投递给视觉算法,做AI分析,本文以ffmpeg和大牛直播SDK的SmartPlayer为例,介绍下相…

计算机网络-MSTP概述

一、RSTP/STP的缺陷与不足 前面我们学习了RSTP对于STP的一些优化与快速收敛机制。但在划分VLAN的网络中运行RSTP/STP,局域网内所有的VLAN共享一棵生成树,被阻塞后的链路将不承载任何流量,无法在VLAN间实现数据流量的负载均衡,导致…

ios 快捷指令扩展(Intents Extension)简单使用 swift语言

本文介绍使用Xcode15 建立快捷指令的Extension,并描述如何修改快捷指令的IntentHandler,带参数跳转主应用;以及展示多个选项的快捷指令弹框(配置intentdefinition文件),点击选项带参数跳到主应用的方法 创建快捷指令 快捷指令是…

智能财务 | 数据与融合,激发企业财务数智化转型思考

数据与融合,激发企业财务数智化转型思考 用友持续深耕企业财务领域,见证中国企业走过了财务电算化、信息化时代,当下共同经历数智化时代。2023 年度,通过走访标杆企业,与高校教授、权威机构学者共同探讨等形式&#xf…

openpnp - 解决“底部相机高级校正成功后, 开机归零时,吸嘴自动校验失败的问题“

文章目录 openpnp - 解决"底部相机高级校正成功后, 开机归零时,吸嘴自动校验失败的问题"概述笔记问题现象1问题现象2原因分析现在底部相机和吸嘴的位置偏差记录修正底部相机位置现在再看看NT1在底部相机中的位置开机归零,看看是否能通过所有校…

DreamClear:中科院与字节联合推出!隐私安全优先的高性能图像修复技术

❤️ 如果你也关注大模型与 AI 的发展现状,且对大模型应用开发非常感兴趣,我会快速跟你分享最新的感兴趣的 AI 应用和热点信息,也会不定期分享自己的想法和开源实例,欢迎关注我哦! 🥦 微信公众号&#xff…

SpringBoot驱动的毕业生招聘信息平台

1 系统概述 1.1 概述  随着社会的快速发展,计算机的影响是全面且深入的。人们的生活水平不断提高,日常生活中毕业生对招聘平台方面的要求也在不断提高,需要招聘平台的人数更是不断增加,使得毕业生信息招聘平台的开发成为必需而且…

Mac程序坞窗口预览的方法来了

当你同一程序内打开的窗口过多的时候,在Mac上想要切换就只能打开程序然后在内部进行切换,没办法直达你想要打开的窗口,多了一步的操作,那么如何才能一步到位呢 如果程序坞有应用程序的缩略图,是不是就可以一步到位了&…

【C/C++】结构体的定义

零.导言 在上一篇博客中,我讲解了qsort函数,并在其中提到了结构体数组的排序,那么结构体是什么呢? 接下来我将详细讲解结构体的定义。 一,结构体是什么? 结构体是自定义的数据类型,可以存放自定义的数据。…

JavaScript 中如何识别异步函数?

我们如何判断一个函数是否是异步函数(async function)呢? 遇到问题的思考过程是什么呢,首先需要找到二者的区别,那就打印看一下,然后在思考如何做。 由此可以看出二者的差异。 1、使用 typeof 检查函数类…

springboot学生请假管理系统-计算机毕业设计源码12712

摘 要 从20年代开始,计算机在人们的生活和工作中广泛应用,成为了人们生活、工作的得力助手。计算机深入到每个家庭和每个工作场所,网络办公和网络教学取代了传统的手工记录和管理方式。使用计算机办公可以不受时间和地点限制,通过…

频率限制:WAF保护网站免受恶意攻击的关键功能

频率限制(Rate Limiting)是一项有效的安全措施,用于控制每个 IP 地址的访问速率,以防止恶意用户利用大量请求对网站进行攻击,例如防止 CC 攻击等。频率限制不仅能保护网站资源,还能提升服务的稳定性。 下面…

ClickHouse 神助攻:纽约城市公共交通管理(MTA)数据应用挑战赛

本文字数:13198;估计阅读时间:33 分钟 作者:The PME Team 本文在公众号【ClickHouseInc】首发 我们一向对开放数据挑战充满热情,所以当发现 MTA(城市交通管理局)在其官网发起了这样的挑战时&…

什么是数据中心?

数据中心是一个专门用于容纳大量联网计算机设备的设施,这些设备共同协作,以处理、存储和传输数据。现代社会中,大部分高科技公司都依赖数据中心来提供在线服务,例如网站、应用程序和云服务等。可以说,数据中心是互联网…

【论文精读】ID-like Prompt Learning for Few-Shot Out-of-Distribution Detection

🌈 个人主页:十二月的猫-CSDN博客 🔥 系列专栏: 🏀论文精读_十二月的猫的博客-CSDN博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 注:下文…

【文心智能体 | AI大师工坊】如何使用智能体插件,完成一款旅游类智能体的开发,来体验一下我的智能体『​​​​​​​背包客』

🚀『背包客』点击前往体验:https://mbd.baidu.com/ma/s/d7RHMlWh 最近参加了百度文心智能体平台AI大师工坊🎉活动,在这个活动中,我利用文心平台提供的各种插件、大模型等工具,打造了一个工具类的智能体应用…

理解ADC:为什么量化噪声也会产生谐波?附带介绍 Dither(抖动)

前言 今天继续从经典的 ADI 《MT-001》说起,通常情况下量化噪声是白噪声,但如果量化噪声与输入信号之间存在相关性,就不能被当做白噪声对待。 文中举了一个有意思的例子:理想 ADC 的采样频率为 80 MSPS ,一种情况输入…

从0到1构建 UniApp + Vue3 + TypeScript 移动端跨平台开源脚手架

🚀 作者主页: 有来技术 🔥 开源项目: youlai-mall 🍃 vue3-element-admin 🍃 youlai-boot 🍃 vue-uniapp-template 🌺 仓库主页: GitCode💫 Gitee &#x1f…

Docker部署教程:打造流畅的斗地主网页小游戏

Docker部署教程:打造流畅的斗地主网页小游戏 一、项目介绍项目简介项目预览二、系统要求环境要求环境检查Docker版本检查检查操作系统版本三、部署斗地主网页小游戏下载镜像创建容器检查容器状态查看容器日志安全设置四、访问斗地主网页小游戏五、总结一、项目介绍 项目简介 …

计算机视觉常用数据集Cityscapes的介绍、下载、转为YOLO格式进行训练

我在寻找Cityscapes数据集的时候花了一番功夫,因为官网下载需要用公司或学校邮箱邮箱注册账号,等待审核通过后才能进行下载数据集。并且一开始我也并不了解Cityscapes的格式和内容是什么样的,现在我弄明白后写下这篇文章,用于记录…