当前位置: 首页 > article >正文

使用 Python 操作 Excel 文件中的工作表(添加和删除)

在处理复杂的 Excel 文档时工作表的管理是一项基础而重要的技能。无论是需要为不同部门创建独立的数据表格还是清理不再需要的旧数据灵活地添加和删除工作表都能帮助我们更好地组织和管理数据。本文将介绍如何使用 Python 和 Spire.XLS 库来管理 Excel 工作簿中的工作表包括添加新工作表、删除现有工作表以及获取工作表信息等常用操作。为什么需要程序化管理工作表在实际业务场景中我们经常需要动态管理工作表自动化报表生成根据数据源自动创建对应数量的工作表例如为每个销售区域生成独立的统计表格数据整理与归档定期清理过期的工作表保持文件整洁模板化处理基于标准模板批量生成包含特定工作表结构的新文件动态数据结构根据用户需求动态调整工作表数量和名称通过编程方式实现这些操作可以显著提升工作效率减少重复性手工劳动。环境准备首先需要安装 Spire.XLS for Python 库。可以通过 pip 命令进行安装pipinstallSpire.XLS安装完成后即可在 Python 脚本中导入并使用该库提供的工作表管理功能。添加新工作表基本添加操作向现有工作簿中添加新工作表是最常见的操作之一。Spire.XLS 提供了Add方法来实现这一功能该方法允许我们指定新工作表的名称并返回新创建的工作表对象方便后续操作。以下代码演示了如何加载一个现有的 Excel 文件并向其中添加一个名为AddedSheet的新工作表fromspire.xlsimport*fromspire.xls.commonimport*# 定义输入输出文件路径inputFile./Demos/Data/AddWorksheet.xlsxoutputFileAddWorksheet.xlsx# 创建 Workbook 对象并加载文件workbookWorkbook()workbook.LoadFromFile(inputFile)# 添加一个名为 AddedSheet 的新工作表sheetworkbook.Worksheets.Add(AddedSheet)# 在新工作表中写入内容sheet.Range[C5].TextThis is a new sheet.# 保存文件并释放资源workbook.SaveToFile(outputFile,ExcelVersion.Version2013)workbook.Dispose()在这个示例中Worksheets.Add()方法接受一个字符串参数作为工作表名称并返回新创建的工作表对象。我们可以直接使用这个对象来设置单元格内容、格式化样式或进行其他操作。这种方式非常直观适合需要在添加工作表后立即进行内容填充的场景。批量创建工作表当需要一次性创建多个工作表时可以使用CreateEmptySheets方法。这个方法在创建空白工作簿时特别有用可以快速生成指定数量的工作表。下面的示例展示了如何创建一个包含 5 个工作表的 Excel 文件并为每个工作表命名和填充示例数据fromspire.xls.commonimport*fromspire.xlsimport*# 定义输出文件路径outputFileCreateAnExcelWithFiveSheet.xlsx# 创建空的 Workbook 对象workbookWorkbook()# 创建 5 个空白工作表workbook.CreateEmptySheets(5)# 遍历每个工作表设置名称并填充数据foriinrange(0,5):sheetworkbook.Worksheets[i]sheet.NameSheetstr(i)# 在每个工作表中填充示例数据forrowinrange(1,151):forcolinrange(1,51):sheet.Range[row,col].Textrowstr(row) colstr(col)# 保存文件并释放资源workbook.SaveToFile(outputFile,ExcelVersion.Version2010)workbook.Dispose()这个示例展示了完整的批量创建流程使用CreateEmptySheets(5)一次性创建 5 个空白工作表通过索引访问每个工作表并设置名称使用嵌套循环为每个工作表填充示例数据这种方法非常适合生成标准化的多工作表模板或者在数据处理前预先准备好所需的工作表结构。删除工作表按索引删除工作表当工作簿中包含不再需要的工作表时我们可以将其删除以保持文件整洁。Spire.XLS 提供了RemoveAt方法允许我们通过索引位置来删除指定的工作表。以下代码展示了如何删除工作簿中的第二个工作表索引为 1fromspire.xlsimport*fromspire.xls.commonimport*# 定义输入输出文件路径inputFile./Demos/Data/RemoveWorksheet.xlsxoutputFileRemoveWorksheet.xlsx# 创建 Workbook 对象并加载文件workbookWorkbook()workbook.LoadFromFile(inputFile)# 通过索引删除第二个工作表索引从 0 开始workbook.Worksheets.RemoveAt(1)# 保存文件并释放资源workbook.SaveToFile(outputFile,ExcelVersion.Version2013)workbook.Dispose()需要注意的是工作表的索引是从 0 开始的因此RemoveAt(1)实际上删除的是第二个工作表。在执行删除操作后剩余工作表的索引会自动调整。如果需要根据名称而非索引来删除工作表可以先遍历工作表集合找到对应的索引然后再执行删除操作。智能删除根据条件筛选在实际应用中我们可能需要根据特定条件来决定删除哪些工作表。例如删除所有名称包含临时或备份字样的工作表。虽然基础 API 只提供了按索引删除的功能但我们可以结合遍历逻辑来实现更智能的删除策略。fromspire.xlsimport*fromspire.xls.commonimport*# 定义输入输出文件路径inputFile./Demos/Data/RemoveWorksheet.xlsxoutputFileRemoveWorksheet_Conditional.xlsx# 创建 Workbook 对象并加载文件workbookWorkbook()workbook.LoadFromFile(inputFile)# 收集需要删除的工作表索引从后往前遍历避免索引变化问题indexes_to_remove[]foriinrange(workbook.Worksheets.Count-1,-1,-1):sheetworkbook.Worksheets[i]# 如果工作表名称包含特定关键词则标记为删除if临时insheet.Nameor备份insheet.Name:indexes_to_remove.append(i)# 执行删除操作forindexinindexes_to_remove:workbook.Worksheets.RemoveAt(index)# 保存文件并释放资源workbook.SaveToFile(outputFile,ExcelVersion.Version2013)workbook.Dispose()这个示例展示了如何实现条件删除从后往前遍历所有工作表收集需要删除的索引从后往前删除是为了避免删除操作导致索引变化而影响后续删除根据工作表名称中的关键词判断是否需要删除这种模式可以灵活扩展支持各种复杂的删除条件。获取工作表信息在管理工作表之前了解当前工作簿中包含哪些工作表是非常有用的。我们可以遍历工作表集合来获取所有工作表的名称和其他属性。以下代码演示了如何获取并保存所有工作表的名称fromspire.xlsimport*fromspire.xls.commonimport*defAppendAllText(fname:str,text:list):辅助函数将列表中的文本写入文件fpopen(fname,w,encodingutf-8)forsintext:fp.write(s\n)fp.close()# 定义输入输出文件路径inputFile./Demos/Data/WorksheetSample3.xlsxoutputFileOutputGetWorksheetNames.txt# 创建 Workbook 对象并加载文件workbookWorkbook()workbook.LoadFromFile(inputFile)# 获取所有工作表的名称sb[]forsheetinworkbook.Worksheets:sb.append(sheet.Name)# 将工作表名称保存到文本文件AppendAllText(outputFile,sb)# 释放资源workbook.Dispose()这个示例展示了一个实用的工具函数可以提取工作簿中所有工作表的名称并保存到文本文件中。这种功能在以下场景中非常有用文档审计快速了解大型 Excel 文件的结构自动化处理在批量处理前确认工作表列表生成目录为复杂的工作簿创建索引或导航页面实际应用综合示例在实际工作中添加和删除工作表的操作往往需要结合使用。以下是一个综合示例展示了如何根据数据动态管理工作表fromspire.xlsimport*fromspire.xls.commonimport*# 定义输出文件路径outputFileDynamicWorksheetManagement.xlsx# 创建新的 Workbook 对象workbookWorkbook()# 假设我们有三个部门的数据需要分别放入不同的工作表departments[销售部,市场部,技术部]# 为每个部门创建一个工作表fordeptindepartments:sheetworkbook.Worksheets.Add(dept)# 在每个工作表中添加标题sheet.Range[A1].Valuef{dept}- 月度报告sheet.Range[A1].Style.Font.IsBoldTruesheet.Range[A1].Style.Font.Size14# 添加示例数据列标题sheet.Range[A3].Value项目名称sheet.Range[B3].Value金额sheet.Range[C3].Value日期# 设置列标题样式sheet.Range[A3:C3].Style.Font.IsBoldTruesheet.Range[A3:C3].Style.ColorColor.LightGray# 删除默认创建的空白工作表如果有whileworkbook.Worksheets.Countlen(departments):workbook.Worksheets.RemoveAt(0)# 保存文件并释放资源workbook.SaveToFile(outputFile,ExcelVersion.Version2013)workbook.Dispose()这个综合示例展示了完整的工作表管理流程根据部门列表动态创建工作表为每个工作表设置名称和初始内容清理不需要的默认工作表最终得到一个结构清晰、内容规范的多工作表文件实用技巧在管理工作表时以下技巧可以帮助提高效率和代码质量索引注意事项删除工作表后剩余工作表的索引会重新排列。如果需要删除多个工作表建议从后往前遍历或者先收集索引再统一删除。名称唯一性工作表名称在工作簿中必须是唯一的。尝试添加同名工作表会导致错误因此在添加前应检查名称是否已存在。最小工作表数量Excel 工作簿至少需要保留一个工作表不能删除所有工作表。在执行删除操作前应检查工作表数量。性能优化当需要大量修改工作表时建议在内存中完成所有操作后再保存文件避免频繁的磁盘 I/O 操作。总结通过本文的介绍我们学习了使用 Python 和 Spire.XLS 库管理 Excel 工作表的多种方法使用Add方法添加单个新工作表并可立即对其进行操作使用CreateEmptySheets方法批量创建空白工作表使用RemoveAt方法按索引删除工作表结合遍历逻辑实现条件删除和智能管理使用遍历工作表集合获取工作表信息这些方法为 Excel 文件的自动化处理提供了坚实的基础。掌握这些技巧后您将能够更高效地管理和组织复杂的 Excel 文档实现真正的自动化办公流程。

相关文章:

使用 Python 操作 Excel 文件中的工作表(添加和删除)

在处理复杂的 Excel 文档时,工作表的管理是一项基础而重要的技能。无论是需要为不同部门创建独立的数据表格,还是清理不再需要的旧数据,灵活地添加和删除工作表都能帮助我们更好地组织和管理数据。 本文将介绍如何使用 Python 和 Spire.XLS 库…...

HBuilderX真机调试报错找不到android_base.apk?别慌,3个方法帮你快速搞定(附详细路径)

HBuilderX真机调试报错找不到android_base.apk?3种实战解决方案详解 遇到HBuilderX真机调试时控制台突然报错"未查找到基座位置plugins\launcher\base\android_base.apk",这确实会让开发者措手不及。这个错误通常发生在首次尝试连接安卓设备进…...

告别暴力穷举!用ip33在线工具手工反算1~4字节CRC32校验码的原始数据

告别暴力穷举!手工反算1~4字节CRC32校验码的数学艺术 在数据校验的世界里,CRC32就像一位沉默的守门人,它用32位的校验码守护着数据的完整性。但鲜为人知的是,当面对1-4字节的短数据时,这位守门人的规则可以被优雅地逆…...

eMarker芯片如何保障100W+PD充电的安全

一、100W以上充电的独特安全挑战当充电功率跨过100W门槛,安全风险的复杂性和严重性都进入了全新量级。根据UL 62368-1标准,100W是PS2与PS3能量源等级的分界线——PS3能量源等级(100W及以上)意味着设备和线缆发生点火和火灾蔓延的风…...

Python怎么检查安装成功_版本号查询与Hello World测试

Python命令是否可用取决于PATH环境变量是否包含其安装路径;若python --version报错,应尝试python3 --version等变体,并通过import sys; print(sys.version)确认实际运行版本。python 命令是否可用:先看终端能不能认出它很多问题其…...

Chrom和PBV算法全解析:医疗级RPPG心率检测的5个关键陷阱

Chrom和PBV算法全解析:医疗级RPPG心率检测的5个关键陷阱 在ICU病房的昏暗灯光下,护士长李敏正盯着监护仪上剧烈波动的心率曲线皱眉——这位刚完成心脏手术的患者,因传统接触式电极导致皮肤过敏,而基于摄像头的非接触监测系统却频繁…...

GraalVM安全性最佳实践(FIPS 140-3合规版):从JNI绑定校验、证书硬编码剔除到Bouncy Castle静态裁剪全流程

第一章:GraalVM静态镜像安全性全景概览GraalVM 静态镜像(Native Image)通过提前编译(AOT)将 Java 应用构建成独立、无依赖的二进制可执行文件,显著减少了运行时攻击面——既消除了 JVM 解释器、JIT 编译器、…...

MTK Camera调试实战:搞定I2C报错、图像反向、颜色异常等常见问题

MTK Camera调试实战:从寄存器操作到硬件测量的全链路排错指南 当你在实验室盯着那块始终黑屏的Camera模组,或是产线上反复出现颜色失真的测试样机时,真正考验的不仅是技术手册的熟悉程度,更是系统化的调试思维。这份指南将带你穿越…...

【稀缺首发】Blazor Hybrid 2026生产就绪架构图(含MAUI 7.0集成深度):仅开放给前500名订阅者下载的微软Partner认证模板包

第一章:Blazor Hybrid 2026生产就绪架构全景概览Blazor Hybrid 2026代表了微软跨平台富客户端开发的最新演进形态,其核心目标是统一Web与原生体验,在保持Razor语法一致性的同时,深度集成平台能力、离线可靠性、安全沙箱及企业级可…...

别再死磕大卷积核了!用3x3小核+ShiftwiseConv,在ImageNet上跑出SOTA的保姆级解读

3x3小核ShiftwiseConv:在ImageNet上实现SOTA的实战指南 当整个计算机视觉社区沉迷于堆叠更大的卷积核时,CVPR 2025的一项研究却反其道而行——用精巧的3x3小核配合ShiftwiseConv模块,在ImageNet上实现了超越31x31大核模型的性能。这并非简单…...

不用死刷算法题!从零手搓伪随机数,吃透DP、状态机与缓存优化

不用死刷算法题!从零手搓伪随机数,吃透DP、状态机与缓存优化 文章目录不用死刷算法题!从零手搓伪随机数,吃透DP、状态机与缓存优化一、核心训练思路:从「简单迭代」到「多阶依赖」二、入门:从简单迭代开始&…...

Open Images:大规模多标签图像分类与目标检测数据集的技术实现

Open Images:大规模多标签图像分类与目标检测数据集的技术实现 【免费下载链接】dataset The Open Images dataset 项目地址: https://gitcode.com/gh_mirrors/dat/dataset Open Images是由Google构建的大规模视觉数据集,为计算机视觉研究提供了包…...

stock-sdk-mcp 的实践整理倨

一、什么是urllib3? urllib3 是一个用于处理 HTTP 请求和连接池的强大、用户友好的 Python 库。 它可以帮助你: 发送各种 HTTP 请求(GET, POST, PUT, DELETE等)。 管理连接池,提高网络请求效率。 处理重试和重定向。 支…...

IDM永久使用开源解决方案:安全验证与实战指南

IDM永久使用开源解决方案:安全验证与实战指南 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script 问题诊断:破解工具背后的隐藏风险 痛点呈现…...

ArcGIS空间连接实战:如何高效挂接地图斑属性到mdb数据库

ArcGIS空间连接实战:高效挂接地图斑属性到mdb数据库的完整指南 在空间数据处理工作中,将属性数据与空间图形精准关联是GIS分析的基础环节。许多技术人员在使用ArcGIS进行地图斑属性挂接时,常遇到数据不匹配、连接失败或效率低下的问题。本文将…...

外卖霸王餐API接口架构设计思路分析

外卖霸王餐API接口架构设计思路分析 对于开发者而言,构建一套高并发、高可用的外卖霸王餐API接口架构,是实现流量主与外卖平台(美团、饿了么)数据互通的关键。本文将基于俱美开放平台(http://www.baodanbao.com.cn)的技术实践&am…...

工业网关上线前必须做的7项压力测试,第4项让3家客户当场终止验收:PHP-FPM+Docker+K8s边缘集群压测黄金指标手册

第一章:工业网关上线前必须做的7项压力测试,第4项让3家客户当场终止验收:PHP-FPMDockerK8s边缘集群压测黄金指标手册为什么第4项测试如此关键 第4项测试聚焦于 PHP-FPM 在高并发短连接场景下的子进程回收与内存泄漏叠加效应——这正是导致三家…...

手把手教你用Video-LLaVA和LoRA,微调自己的视频异常分析‘侦探’(附代码思路)

用Video-LLaVA和LoRA打造视频异常分析专家的实战指南 当监控摄像头捕捉到一场突如其来的骚乱,或是生产线上的机械臂突然失控,传统算法只能给出冷冰冰的"异常报警"。而现在,我们可以教会AI像经验丰富的安全专家那样,不仅…...

Google 迎来「DeepSeek 时刻」:TurboQuant算法实现bit无损、×加速、×压缩、零预处理范

从 UI 工程师到 AI 应用架构者 13 年前,我的工作是让按钮在 IE6 上对齐; 13 年后,我用 fetch-event-source 订阅大模型的“思维流”,用 OCR 解锁图片中的文字——前端,正在成为 AI 产品的第一道体验防线。 最近&#x…...

彻底搞懂Pinecone、Chroma、Weaviate:向量数据库架构拆解,看这篇就够了!

向量数据库存储 Embedding,也就是文本、图像或音频的数值表示,并在查询时检索语义上最接近的结果。RAG 系统正是基于这一机制运作。本文对比三个主流方案,每个都附有 Python 代码,均来自实际在生产环境中使用三者的经验。 三种选择…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语孛

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作量。 使用 kube…...

开源机器人手终极指南:如何用OpenHand技术解决柔性抓取的三大挑战

开源机器人手终极指南:如何用OpenHand技术解决柔性抓取的三大挑战 【免费下载链接】openhand-hardware CAD files for the OpenHand hand designs 项目地址: https://gitcode.com/gh_mirrors/op/openhand-hardware 当传统机械手面对复杂物体时,为…...

为什么开发者都在使用go-cursor-help?5步掌握Cursor无限试用技巧

为什么开发者都在使用go-cursor-help?5步掌握Cursor无限试用技巧 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Your request has been blocked as our system has detected suspicious activity / Youve reached your trial reque…...

从0到1构建一个ClaudeAgent-工具与执行-Agent循环

在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…...

如何解决网页图片格式转换难题?这款Chrome扩展让效率提升3倍

如何解决网页图片格式转换难题?这款Chrome扩展让效率提升3倍 【免费下载链接】Save-Image-as-Type Save Image as Type is an chrome extension which add Save as PNG / JPG / WebP to the context menu of image. 项目地址: https://gitcode.com/gh_mirrors/sa/…...

WPF新手村教程(七)—— 终章(MVVM架构初见杀)俑

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

一篇文章带你了解MyBatis!!!

一、引言在之前提到的三层架构:控制层controller、业务层service、持久层dao,里面的持久层,顾名思义:承担了数据持久化的核心职责;这篇文章讲述的是常用的持久层框架---MyBatis二、入门程序准备工作:创建sp…...

连续血糖监测数据集终极指南:解锁糖尿病研究的标准化数据宝库

连续血糖监测数据集终极指南:解锁糖尿病研究的标准化数据宝库 【免费下载链接】Awesome-CGM List of CGM datasets 项目地址: https://gitcode.com/gh_mirrors/aw/Awesome-CGM 在精准医疗与人工智能交叉融合的时代,连续血糖监测(CGM&a…...

免费智能风扇控制终极指南:3步让你的电脑静音又冷静

免费智能风扇控制终极指南:3步让你的电脑静音又冷静 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/F…...

2026年智能巡检管理系统如何让设备隐患无处遁形?

传统的设备巡检,本质上是一场“信任游戏”。我信任员工去看了,员工信任自己画了钩,结果往往是——等到设备真的坏了、管道真的漏了,翻开那本厚厚的巡检记录,上面依然写满了“正常”。直到我们引入了智能巡检管理系统&a…...