Python 教程:快速复制 Excel 工作表

在日常办公和数据处理中,复制 Excel 工作表是一个非常高频的需求。无论是在同一个工作簿中备份数据、按月生成结构相同的报表,还是将外部协同表格中的数据整合到主工作簿中,高效、精准的复制功能都能大幅提升自动化办公的效率。

今天我们将介绍如何使用 Free Spire.XLS for Python 库,通过几行简单的代码复制 Excel 工作表。不仅会涵盖同工作簿复制和跨工作簿复制两种常见的需求,还提供在复制过程中处理页面设置、视图锁定以及行列宽、公式等细节设置,帮助你创建一个更加专业、完整的 Excel 文件。

核心准备工作

在进入文章的主题之前,我们需要先搭建好开发环境。Free Spire.XLS for Python 是一个功能强大且完全独立的类库,在不安装Microsoft Excel的情况下,就能轻松完成创建、读取、编辑和转换 Excel 文件的工作。

你可以通过 pip 命令将其安装到你的 Python 环境中:

bash 复制代码
pip install Spire.Xls.Free

安装完成后,我们就可以开始构建核心的脚本了。

在同一个 Excel 工作簿中复制工作表

在处理日常报表时,我们经常需要以某个现有的数据模板为基础,在同一个 Excel 文件中快速克隆出一个或多个新的工作表。比如,从 1 月数据模板直接复制出 2 月数据的初始框架。

使用 Free Spire.XLS 提供的 Workbook.Worksheets.CopyFrom() 方法,我们可以快速复制工作表,并且新工作表会保留原表的格式。

完整代码示例

python 复制代码
from spire.xls import *
from spire.xls.common import *

# 创建一个工作簿对象
workbook = Workbook()

# 从文件中加载一个工作簿
workbook.LoadFromFile("示例1.xlsx")

# 获取源工作表
sourceSheet = workbook.Worksheets[0]

# 设置目标工作表的名称为源工作表名称 + "_复制"
sheetName = sourceSheet.Name + "_复制"

# 在同一工作簿中添加目标工作表,并使用设置的名称
destSheet = workbook.Worksheets.Add(sheetName)

# 将源工作表内容复制到目标工作表
destSheet.CopyFrom(sourceSheet)

# 将工作簿保存到文件,使用2016版本的Excel格式
workbook.SaveToFile("在同一个Excel工作簿中复制工作表.xlsx", ExcelVersion.Version2016)

# 释放工作簿的资源
workbook.Dispose()

关键代码解析

在上方的代码中,我们主要用到了创建和复制两个步骤:

  • workbook.Worksheets.Add():首先在工作簿中动态创建一个指定名称的全新空白工作表对象。
  • destSheet.CopyFrom() :这是代码的核心方法。通过目标工作表调用 CopyFrom(),并传入源工作表对象。它会在后台进行深度数据迁移,不仅能将源表中的数据、单元格样式、条件格式等复制过来,还会自动适配目标表的结构。

从另一个工作簿中复制 Excel 工作表

除了在单个文件内部进行克隆,跨跨文件的数据整合同样非常普遍。例如,将各个员工独立上报的 Excel 业绩表,汇总合并到一个总的目标工作簿中。

跨工作簿复制的核心逻辑是:同时打开源工作簿和目标工作簿,在目标文件中创建新表后进行 CopyFrom() 跨文件复制。同时,为了防止字体或颜色由于环境不同而走样,还需要同步两者的主题样式。

完整代码示例

python 复制代码
from spire.xls import *
from spire.xls.common import *

# 创建一个工作簿对象
sourceWorkbook = Workbook()

# 从文件中加载一个工作簿
sourceWorkbook.LoadFromFile("示例1.xlsx")

# 获取源工作表
sourceSheet = sourceWorkbook.Worksheets[0]

# 设置目标工作表的名称为源工作表名称 + "_复制"
sheetName = sourceSheet.Name + "_复制"

# 创建一个目标工作簿对象
destWorkbook = Workbook()

# 从文件中加载另一个工作簿
destWorkbook.LoadFromFile("示例2.xlsx")

# 添加目标工作表,并使用设置的名称
destSheet = destWorkbook.Worksheets.Add(sheetName)

# 将源工作表内容复制到目标工作表
destSheet.CopyFrom(sourceSheet)

# 复制源工作簿的主题样式到目标工作簿
destWorkbook.CopyTheme(sourceWorkbook)

# 将目标工作簿保存到文件,使用2016版本的Excel格式
destWorkbook.SaveToFile("将工作表复制到另一个Excel工作簿.xlsx", ExcelVersion.Version2016)

# 释放源工作簿的资源
sourceWorkbook.Dispose()

# 释放目标工作簿的资源
destWorkbook.Dispose()

关键代码解析

跨文件操作的关键在于处理两个不同的 Workbook 实例:

  • destSheet.CopyFrom()CopyFrom() 方法非常智能,它不仅支持同一个 Excel 文件内的数据传输,也能完美支持跨越不同 Workbook 对象的表数据复制。执行时,类库会在后台自动处理跨文件的底层 XML 结构和数据映射。
  • destWorkbook.CopyTheme() :Excel 的颜色、字体往往依赖于文件本身定义的主题方案。如果不调用这一步,复制过去的表格可能会因为目标工作簿的主题不同,而出现颜色变色、字体走样的情况。通过 CopyTheme() 可以确保两个文件的视觉效果保持一致。

复制中的高级个性化设置与样式覆盖

在执行 CopyFrom() 操作时,源工作表中的行列宽度、窗口冻结以及页面打印设置其实已经被默认同步克隆过来了。但在实际的应用中,我们可能需要对新生成的表格进行二次加工或样式覆盖------例如为新装载的数据动态扩充列宽,或者为汇总表定制不同的打印方向。你可以根据实际的定制化需求,灵活地将以下代码片段嵌入到上面的完整代码中:

动态调整行列宽度

虽然克隆时会带过来源表的行列宽,但由于新表格可能会用来填充不同的业务数据,某些字段长度可能会发生变化。如果新数据的长度超出了原单元格的承载范围,Excel 就会显示 ### 溢出符号,不便于阅览。

利用下面这段代码,你可以在工作表复制完成后,为指定行或列重新划定尺寸,覆盖原有的行高列宽:

python 复制代码
# 调整特定列的列宽(例如:为容纳更长的数据,将目标表的第1列即A列宽度设为25)
destSheet.SetColumnWidth(1, 25.0) 

# 调整特定行等行高(例如:将目标表的第1行即标题行高度设为30)
destSheet.SetRowHeight(1, 30.0)    

自定义页面与打印设置

当你需要为生成的新表重写打印边界,或者改变其输出方向时,可以通过操作 PageSetup 属性组进行显式覆盖:

python 复制代码
# 将目标表显式修改为横向打印布局(Landscape),覆盖源表的纵向设置
destSheet.PageSetup.Orientation = "Landscape" 

# 重新规划页边距(单位:英寸)
destSheet.PageSetup.TopMargin = 0.5            # 上边距
destSheet.PageSetup.BottomMargin = 0.5         # 下边距

# 重新指定针对新表的打印区域,避免打印出表格外无意义的空白单元格
destSheet.PageSetup.PrintArea = "A1:G20"       

重设冻结窗格

在复制完成后,我们还可以对目标表的视图锁定状态进行调整。通过调用窗格冻结的 API,我们可以把关键的行列固定在屏幕上,极大地提升最终用户的阅读体验:

python 复制代码
# 重新锁定窗口视图:该方法接收行索引和列索引(从1开始计数)
# FreezePanes(2, 2) 意味着冻结第二行和第二列上方/左侧的内容,即固定目标表的"第一行"和"第一列"
destSheet.FreezePanes(2, 2) 

强制刷新全局公式计算

如果源工作表中包含了 SUM、VLOOKUP 或者其他依赖上下文的复杂计算公式,跨文件复制可能会引发公式引用关系重构。直接保存的话有些文件可能无法在打开时自动刷新数值。

在保存文件前的最后一步,我们可以调用目标工作簿的计算引擎进行强制重算,确保输出的 Excel 在任何设备上打开时,显示的都是最终正确的数值:

python 复制代码
# 激活目标工作簿内置的计算引擎,强制更新其内部所有公式的最新计算结果
destWorkbook.CaculateAllValue()

总结

本文从基础到进阶,详细介绍了使用 Free Spire.XLS for Python 复制 Excel 工作表的两种主要操作。无论是同簿克隆、跨簿转移,还是在复制后进行自定义设置,该类库都提供了非常直观的 API 支持。

在实际构建企业级自动化脚本时,灵活组合上述代码片段,不仅能够帮你省去手动复制粘贴的繁琐,更能确保产出报表格式的绝对标准与严谨。

相关推荐
lunzi_08263 小时前
【学习笔记】《Python编程 从入门到实践》第2章:变量命名规则、字符串操作与数值类型详解
笔记·python·学习
是三旬老汉。3 小时前
宇树G1-D机器人端推理开发记录
python·机器人
databook3 小时前
轨迹的蓝图:方程求解与交点计算
python·数学·动效
隔壁大炮3 小时前
MNE-Python 第1天学习笔记:环境搭建与数据初探
python·eeg·bci·mne·脑电数据处理
晚烛3 小时前
CANN 模型热更新:不停机模型切换与无缝更新实战指南
开发语言·python
ZPC82103 小时前
单物体最优抓取轨迹生成
python·opencv·计算机视觉
若兰幽竹3 小时前
【大模型应用】抖音爆款视频深度分析系统:流水线式AI逆向拆解流量密码,精准预测播放量!
人工智能·python·音视频·抖音爆款分析
喜爱波波奶茶3 小时前
doxygen python配置
python
这是空气3 小时前
Python 入门教程3
python