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

Python 教程:快速复制 Excel 工作表 核心准备工作在进入文章的主题之前我们需要先搭建好开发环境。Free Spire.XLS for Python 是一个功能强大且完全独立的类库在不安装Microsoft Excel的情况下就能轻松完成创建、读取、编辑和转换 Excel 文件的工作。你可以通过 pip 命令将其安装到你的 Python 环境中pip install Spire.Xls.Free安装完成后我们就可以开始构建核心的脚本了。在同一个 Excel 工作簿中复制工作表在处理日常报表时我们经常需要以某个现有的数据模板为基础在同一个 Excel 文件中快速克隆出一个或多个新的工作表。比如从 1 月数据模板直接复制出 2 月数据的初始框架。使用 Free Spire.XLS 提供的Workbook.Worksheets.CopyFrom()方法我们可以快速复制工作表并且新工作表会保留原表的格式。完整代码示例from spire.xls import * from spire.xls.common import * # 创建一个工作簿对象 workbook Workbook() # 从文件中加载一个工作簿 workbook.LoadFromFile(北美人口数量前十.xlsx) # 获取源工作表 sourceSheet workbook.Worksheets[0] # 设置目标工作表的名称为源工作表名称 _复制 sheetName sourceSheet.Name _复制 # 在同一工作簿中添加目标工作表并使用设置的名称 destSheet workbook.Worksheets.Add(sheetName) # 将源工作表内容复制到目标工作表 destSheet.CopyFrom(sourceSheet) # 将工作簿保存到文件使用2016版本的Excel格式 workbook.SaveToFile(复制工作表.xlsx, ExcelVersion.Version2016) # 释放工作簿的资源 workbook.Dispose()关键代码解析在上方的代码中我们主要用到了创建和复制两个步骤workbook.Worksheets.Add()首先在工作簿中动态创建一个指定名称的全新空白工作表对象。destSheet.CopyFrom()这是代码的核心方法。通过目标工作表调用CopyFrom()并传入源工作表对象。它会在后台进行深度数据迁移不仅能将源表中的数据、单元格样式、条件格式等复制过来还会自动适配目标表的结构。从另一个工作簿中复制 Excel 工作表除了在单个文件内部进行克隆跨跨文件的数据整合同样非常普遍。例如将各个员工独立上报的 Excel 业绩表汇总合并到一个总的目标工作簿中。跨工作簿复制的核心逻辑是同时打开源工作簿和目标工作簿在目标文件中创建新表后进行CopyFrom()跨文件复制。同时为了防止字体或颜色由于环境不同而走样还需要同步两者的主题样式。完整代码示例from spire.xls import * from spire.xls.common import * # 创建一个工作簿对象 sourceWorkbook Workbook() # 从文件中加载一个工作簿 sourceWorkbook.LoadFromFile(/input/北美人口数量前十.xlsx) # 获取源工作表 sourceSheet sourceWorkbook.Worksheets[0] # 设置目标工作表的名称为源工作表名称 _复制 sheetName sourceSheet.Name _复制 # 创建一个目标工作簿对象 destWorkbook Workbook() # 从文件中加载另一个工作簿 destWorkbook.LoadFromFile(/input/南美人口数量前十.xlsx) # 添加目标工作表并使用设置的名称 destSheet destWorkbook.Worksheets.Add(sheetName) # 将源工作表内容复制到目标工作表 destSheet.CopyFrom(sourceSheet) # 复制源工作簿的主题样式到目标工作簿 destWorkbook.CopyTheme(sourceWorkbook) # 保存修改后文件 destWorkbook.SaveToFile(/output/复制不同文件的工作表.xlsx, ExcelVersion.Version2016) sourceWorkbook.Dispose() destWorkbook.Dispose()关键代码解析跨文件操作的关键在于处理两个不同的 Workbook 实例destSheet.CopyFrom()CopyFrom()方法非常智能它不仅支持同一个 Excel 文件内的数据传输也能完美支持跨越不同 Workbook 对象的表数据复制。执行时类库会在后台自动处理跨文件的底层 XML 结构和数据映射。destWorkbook.CopyTheme()Excel 的颜色、字体往往依赖于文件本身定义的主题方案。如果不调用这一步复制过去的表格可能会因为目标工作簿的主题不同而出现颜色变色、字体走样的情况。通过CopyTheme()可以确保两个文件的视觉效果保持一致。复制中的高级个性化设置与样式覆盖在执行CopyFrom()操作时源工作表中的行列宽度、窗口冻结以及页面打印设置其实已经被默认同步克隆过来了。但在实际的应用中我们可能需要对新生成的表格进行二次加工或样式覆盖——例如为新装载的数据动态扩充列宽或者为汇总表定制不同的打印方向。你可以根据实际的定制化需求灵活地将以下代码片段嵌入到上面的完整代码中动态调整行列宽度虽然克隆时会带过来源表的行列宽但由于新表格可能会用来填充不同的业务数据某些字段长度可能会发生变化。如果新数据的长度超出了原单元格的承载范围Excel 就会显示 ### 溢出符号不便于阅览。利用下面这段代码你可以在工作表复制完成后为指定行或列重新划定尺寸覆盖原有的行高列宽# 调整特定列的列宽例如为容纳更长的数据将目标表的第1列即A列宽度设为25 destSheet.SetColumnWidth(1, 25.0) # 调整特定行等行高例如将目标表的第1行即标题行高度设为30 destSheet.SetRowHeight(1, 30.0)自定义页面与打印设置当你需要为生成的新表重写打印边界或者改变其输出方向时可以通过操作 PageSetup 属性组进行显式覆盖# 将目标表显式修改为横向打印布局Landscape覆盖源表的纵向设置 destSheet.PageSetup.Orientation Landscape # 重新规划页边距单位英寸 destSheet.PageSetup.TopMargin 0.5 # 上边距 destSheet.PageSetup.BottomMargin 0.5 # 下边距 # 重新指定针对新表的打印区域避免打印出表格外无意义的空白单元格 destSheet.PageSetup.PrintArea A1:G20重设冻结窗格在复制完成后我们还可以对目标表的视图锁定状态进行调整。通过调用窗格冻结的 API我们可以把关键的行列固定在屏幕上极大地提升最终用户的阅读体验# 重新锁定窗口视图该方法接收行索引和列索引从1开始计数 # FreezePanes(2, 2) 意味着冻结第二行和第二列上方/左侧的内容即固定目标表的“第一行”和“第一列” destSheet.FreezePanes(2, 2)强制刷新全局公式计算如果源工作表中包含了 SUM、VLOOKUP 或者其他依赖上下文的复杂计算公式跨文件复制可能会引发公式引用关系重构。直接保存的话有些文件可能无法在打开时自动刷新数值。在保存文件前的最后一步我们可以调用目标工作簿的计算引擎进行强制重算确保输出的 Excel 在任何设备上打开时显示的都是最终正确的数值# 激活目标工作簿内置的计算引擎强制更新其内部所有公式的最新计算结果 destWorkbook.CaculateAllValue()