使用C#实现Excel与DataTable互转的方案

 更新时间:2025年08月25日 09:10:55   作者:LSTM97  
在企业级开发中,Excel文件与DataTable(数据表)的互转是报表生成、数据迁移等场景的核心需求,传统方案如OleDb或Office Interop存在内存泄漏、性能低下等问题,且依赖本地Office组件,所以本文给大家介绍了使用C#实现Excel与DataTable互转的方案,需要的朋友可以参考下

引言

在企业级开发中,Excel文件与DataTable(数据表)的互转是报表生成、数据迁移等场景的核心需求。传统方案如OleDb或Office Interop存在内存泄漏、性能低下等问题,且依赖本地Office组件。而 Spire.XLS for .NET 作为企业级文档操作库,具备零依赖、跨平台、全格式支持等特性,本文将详解双向互转的实现方案。

实现方案详解

方法一:Excel→DataTable

实现步骤

  1. 加载Excel文件:使用Workbook类加载文件
  2. 选择工作表:指定目标Sheet索引或名称
  3. 转换逻辑:通过ExportDataTable()方法提取数据
using Spire.Xls;
using System.Data;

try 
{
    // 初始化工作簿
    Workbook workbook = new Workbook();
    workbook.LoadFromFile("Input.xlsx");

    // 获取首个工作表
    Worksheet sheet = workbook.Worksheets[0];
    
    // 转换配置:首行包含列名
    DataTable dt = sheet.ExportDataTable(
        sheet.FirstRow,      // 起始行
        sheet.FirstColumn,   // 起始列
        sheet.LastRow,       // 结束行
        sheet.LastColumn,    // 结束列
        true                // hasColumnNames
    );
}
catch (Exception ex)
{
    Console.WriteLine($"转换失败:{ex.Message}");
}

核心参数

  • HasColumnNames:控制是否将首行作为DataTable列名
  • 边界计算:动态获取LastRow可兼容动态数据区域

方法二:DataTable→Excel

实现步骤

  1. 创建工作簿:初始化Workbook与工作表
  2. 样式配置:设置标题行字体、背景色
  3. 数据填充:通过InsertDataTable()批量写入
using Spire.Xls;
using System.Data;

DataTable dt = GetDataSource(); // 获取数据源

try 
{
    Workbook workbook = new Workbook();
    Worksheet sheet = workbook.Worksheets[0];
    
    // 设置标题样式
    CellStyle style = workbook.Styles.Add("HeaderStyle");
    style.Font.IsBold = true;
    style.Color = Color.LightGray;
    
    // 写入数据(从A1开始)
    sheet.InsertDataTable(dt, true, 1, 1);
    
    // 应用样式到标题行
    sheet.GetRange(1, 1, 1, dt.Columns.Count).CellStyle = style;
    
    // 自适应列宽
    sheet.AllocatedRange.AutoFitColumns();
    
    // 保存文件
    workbook.SaveToFile("Output.xlsx", ExcelVersion.Version2016);
}
catch (Exception ex)
{
    Console.WriteLine($"导出失败:{ex.Message}");
}

性能优化

  • AutoFitColumns() :避免手动计算列宽
  • 批量写入InsertDataTable相比逐行写入效率提升80%

注意事项

  • 大文件处理:建议分批次处理超过10万行的数据集,避免内存溢出
  • 格式兼容性:导出时指定ExcelVersion参数可适配不同版本Office

结语

通过 Workbook.LoadFromFile() 与 Worksheet.ExportDataTable() 的组合,开发者可快速实现双向数据转换。Spire.XLS凭借其对.NET Core的深度支持,在微服务、云端渲染等场景表现卓越。建议通过NuGet获取最新稳定版(Install-Package Spire.XLS)开启高效开发。

以上就是使用C#实现Excel与DataTable互转的方案的详细内容,更多关于C# Excel与DataTable互转的资料请关注脚本之家其它相关文章!

相关文章

  • C#存储相同键多个值的Dictionary实例详解

    C#存储相同键多个值的Dictionary实例详解

    在本篇文章里小编给大家整理的是关于C#存储相同键多个值的Dictionary实例内容,需要的朋友们可以学习下。
    2020-03-03
  • C#不同类型的成员变量(字段)的默认值介绍

    C#不同类型的成员变量(字段)的默认值介绍

    虽然C#编译器为每个类型都设置了默认类型,但作为面向对象的设计原则,我们还是需要对变量进行正确的初始化。实际上这也是C#推荐的做法
    2014-01-01
  • C#中Sleep() 和 Wait()的区别小结

    C#中Sleep() 和 Wait()的区别小结

    Sleep()和 Wait()是两个不同的方法,用于控制线程的执行,本文主要介绍了C#中Sleep()和Wait()的区别小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • 关于C#继承的简单应用代码分析

    关于C#继承的简单应用代码分析

    在本篇文章里小编给大家整理了一篇关于C#继承的简单应用代码分析内容,有兴趣的朋友们可以学习下。
    2021-05-05
  • C#使用WinRar命令进行压缩和解压缩操作的实现方法

    C#使用WinRar命令进行压缩和解压缩操作的实现方法

    这篇文章主要介绍了C#使用WinRar命令进行压缩和解压缩操作的实现方法,涉及C#基于Process类操作WinRar命令的相关实现技巧,代码简洁实用,需要的朋友可以参考下
    2016-06-06
  • C#实现中文日历Calendar

    C#实现中文日历Calendar

    这篇文章介绍了C#实现中文日历Calendar的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • 快速了解如何在.NETCORE中使用Generic-Host建立主机

    快速了解如何在.NETCORE中使用Generic-Host建立主机

    这篇文章主要介绍了如何在.NETCORE中使用Generic-Host建立主机,文中代码非常详细,可供大家参考,感兴趣的朋友不妨阅读完
    2020-05-05
  • C#集合之位数组的用法

    C#集合之位数组的用法

    这篇文章介绍了C#集合之位数组的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • 基于C#实现Windows后台窗口操作与图像处理技术分析

    基于C#实现Windows后台窗口操作与图像处理技术分析

    在Windows编程中,操作后台窗口是一项复杂而有用的技术,它可以用来自动化用户界面测试、应用程序机器人等场景,本文将深入探讨如何在C#中绑定后台窗口、获取后台窗口界面图片,以及在图片中寻找指定图标并获取坐标,需要的朋友可以参考下
    2024-12-12
  • C# wpf 无边框窗口添加阴影效果的实现

    C# wpf 无边框窗口添加阴影效果的实现

    在本篇内容中小编给大家整理了一篇关于C# wpf 无边框窗口添加阴影效果的具体方法内容,有兴趣的朋友们可以学习参考下
    2022-11-11

最新评论