C#实现Excel工作表拆分的项目实践

 更新时间:2026年01月11日 10:50:37   作者:m5655bj  
本文介绍了使用 C# 和 Free Spire.XLS 免费库实现 Excel 工作表拆分的完整方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

概述

在实际数据处理工作中,我们经常需要将包含多个工作表的 Excel 文件拆分成独立的文件,每个文件只包含一个工作表。这种需求在数据分发、报告生成和数据整理等场景中非常常见。例如,财务部门可能需要将包含多个部门数据的合并报表拆分为每个部门单独的报表,或者教育机构需要将包含多个班级成绩的总表拆分为每个班级的成绩单。手动操作不仅费时费力,而且容易出错,因此自动化拆分 Excel 工作表成为提升工作效率的关键。

本文将详细介绍如何使用 C# 和免费库 Free Spire.XLS 实现 Excel 工作表的拆分功能。我们将从技术栈介绍开始,逐步深入代码实现,并提供优化方案和扩展功能,以帮助读者全面掌握这一实用技能。

技术栈介绍

Free Spire.XLS 库

Free Spire.XLS是一个免费 .NET Excel 组件,提供了丰富的 API,可以轻松实现 Excel 文件的创建、编辑、转换和拆分等功能。与 Microsoft Office Interop 相比,Free Spire.XLS 不需要在服务器上安装 Office,因此更适用于服务器端自动化处理,且性能更优。

环境要求

  • .NET Framework 4.0 或更高版本 / .NET Core / .NET 5+
  • Free Spire.XLS NuGet 包
  • Visual Studio 或任何 C# 开发环境

拆分 Excel 工作表步骤详解

1. 项目准备

首先,我们需要创建一个 C# 控制台应用程序。打开 Visual Studio,选择“创建新项目”->“控制台应用程序(.NET Framework 或 .NET Core)”,为项目命名(例如 SplitWorksheets)。

然后在NuGet包管理控制台中输入以下命令安装 Free Spire.XLS:

Install-Package FreeSpire.XLS

或者通过 Visual Studio 的 NuGet 包管理器图形界面搜索并安装 Free Spire.XLS。

2. 核心代码解析

接下来,我们将逐步解析拆分 Excel 工作表的核心代码。代码的主要思路是:加载源 Excel 文件,遍历其中的每一个工作表,将每个工作表复制到一个新的工作簿中,然后保存为独立的 Excel 文件。

首先,我们需要引入必要的命名空间:

using Spire.Xls;
using System;

然后,在 Main 方法中编写拆分逻辑。以下是每一步的详细说明:

class Program
{
    static void Main(string[] args)
    {
        // 创建Workbook对象实例
        Workbook wb = new Workbook();

        // 加载源Excel文件,支持.xlsx和.xls格式
        wb.LoadFromFile("data.xlsx");

        // 声明新工作簿变量,用于存储单个工作表
        Workbook newWb;

        // 声明字符串变量,用于存储工作表名称
        string sheetName;

        // 指定输出文件夹路径
        string folderPath = "C:\\Users\\Administrator\\Desktop\\Output\\";

        // 确保输出目录存在,如果不存在则创建
        System.IO.Directory.CreateDirectory(folderPath);

        // 遍历源文件中的所有工作表
        for (int i = 0; i < wb.Worksheets.Count; i++)
        {
            // 初始化新的Workbook对象
            newWb = new Workbook();

            // 清除默认工作表
            newWb.Worksheets.Clear();

            // 将源文件中的特定工作表复制到新工作簿
            newWb.Worksheets.AddCopy(wb.Worksheets[i]);

            // 获取当前工作表的名称
            sheetName = wb.Worksheets[i].Name;

            // 保存新工作簿到指定文件夹
            newWb.SaveToFile(folderPath + sheetName + ".xlsx", ExcelVersion.Version2013);
        }

        // 提示用户操作完成
        Console.WriteLine("工作表拆分完成!");
    }
}

3. 核心知识点解析

  • Workbook 类:作为 Free Spire.XLS 的核心类,代表一个完整的 Excel 工作簿,负责文件的加载、创建和保存,所有 Excel 操作均围绕该类展开;
  • Worksheets 属性:返回工作簿中所有工作表的集合,支持通过索引或名称访问单个工作表,Count 属性可获取工作表总数;
  • Worksheets.Clear():清除新工作簿中默认的空白工作表,避免拆分后的文件包含冗余内容;
  • Worksheets.AddCopy():核心复制方法,可将源工作表的所有内容(包括数据、格式、公式、样式等)完整复制到新工作簿;
  • SaveToFile():将工作簿保存为本地文件,支持指定保存路径和 Excel 版本,确保文件格式兼容。

Excel 工作表拆分进阶示例

1. 按条件拆分

在实际场景中,可能不需要拆分所有工作表,而是只拆分满足特定条件的工作表。例如,只拆分名称符合特定模式的工作表:

// 只拆分特定名称的工作表
string[] targetSheets = { "Sheet1", "Data", "Report" };
foreach (string targetSheet in targetSheets)
{
    Worksheet sheet = wb.Worksheets[targetSheet];
    if (sheet != null)
    {
        // 拆分逻辑
    }
}

或者根据工作表索引拆分:

// 拆分前三个工作表
for (int i = 0; i < Math.Min(3, wb.Worksheets.Count); i++)
{
    // 拆分逻辑
}

2. 批量处理多个文件

如果需要处理多个Excel文件,可以将拆分逻辑封装成方法,然后遍历目录下的所有Excel文件:

string sourceFolder = @"C:\Users\Administrator\Desktop\SourceFiles\";
string outputFolder = @"C:\Users\Administrator\Desktop\Output\";
string[] excelFiles = Directory.GetFiles(sourceFolder, "*.xlsx");
foreach (string file in excelFiles)
{
    SplitWorkbook(file, outputFolder);
}

注意事项与常见问题

  1. 使用 using 语句:确保 Workbook 对象在使用完后及时释放,避免内存泄漏。
  2. 内存管理:及时释放不再使用的 Workbook 对象,特别是在循环中创建的对象。
  3. 输出格式:可指定不同 Excel 版本,如Excel 97-2003、Excel 2007、Excel 2010、Excel 2013、Excel 2016等。
  4. 路径权限:确保应用程序有权限读取源文件和写入输出目录。

替代方案

除了 Free Spire.XLS,还可以考虑以下方案:

  • EPPlus:开源免费,但仅支持 .xlsx 格式。对于简单的拆分需求,EPPlus 是一个不错的选择。
  • NPOI:开源免费,支持 .xls 和 .xlsx 格式。功能强大,但API相对复杂。
  • Microsoft Office Interop:需要安装 Office,不推荐用于服务器环境,因为存在性能、稳定性和许可问题。
  • ClosedXML:开源,API友好,但仅支持 .xlsx 格式。

选择哪个库取决于具体需求、预算和技术栈。

总结

本文详细介绍了使用 C# 和 Spire.XLS 库拆分 Excel 工作表的技术实现。关键优势:

  • 代码简洁,逻辑清晰,易于理解和修改。
  • 保持原始格式和数据完整性,确保拆分后的文件与源文件一致。
  • 支持多种 Excel 格式,兼容性强。
  • 易于集成到现有系统,可以作为一个独立工具或嵌入到其他应用程序中。

到此这篇关于C#实现Excel工作表拆分的项目实践的文章就介绍到这了,更多相关C# Excel工作表拆分内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#线程间不能调用剪切板的解决方法

    C#线程间不能调用剪切板的解决方法

    这篇文章主要介绍了C#线程间不能调用剪切板的解决方法,需要的朋友可以参考下
    2014-07-07
  • 深入浅析C#泛型类型

    深入浅析C#泛型类型

    这篇文章主要介绍C#泛型类型,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • C# Fiddler插件实现网站离线浏览功能

    C# Fiddler插件实现网站离线浏览功能

    本文主要介绍了C# Fiddler插件实现网站离线浏览功能的原理与方法。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • C#迷你猜数实例分析

    C#迷你猜数实例分析

    这篇文章主要介绍了C#迷你猜数,实例分析C#操作数字及数组的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • 详谈C++引用&和指针在作为形参时的区别

    详谈C++引用&和指针在作为形参时的区别

    下面小编就为大家带来一篇详谈C++引用&和指针在作为形参时的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • C#中使用DevExpress中的ChartControl实现极坐标图的案例详解

    C#中使用DevExpress中的ChartControl实现极坐标图的案例详解

    这篇文章主要介绍了在C#中使用DevExpress中的ChartControl实现极坐标图,本案例是使用的是DevExpress 18.1.3版本,之前在14版本上也试过,但是有一个弊端就是实现极坐标图的时候,第一个点和最后一个点总是自动多一条闭合线,会形成一个闭合的多边形,因此升级了一下版
    2022-02-02
  • C#事件用法实例浅析

    C#事件用法实例浅析

    这篇文章主要介绍了C#事件用法,以实例形式分析了C#中事件的定义、触发及处理相关技巧,需要的朋友可以参考下
    2015-05-05
  • C#读取多条数据记录导出到Word之图片输出改造

    C#读取多条数据记录导出到Word之图片输出改造

    这篇文章主要为大家详细介绍了C#读取多条数据记录并导出到Word标签模板中的图片输出问题,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2024-11-11
  • C#如何批量修改图片尺寸和DPI

    C#如何批量修改图片尺寸和DPI

    这篇文章主要介绍了C#批量修改图片尺寸和DPI方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • C# 中 “$” 符号的作用以及用法详解

    C# 中 “$” 符号的作用以及用法详解

    这篇文章主要介绍了C# 中 “$” 符号的作用以及用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06

最新评论