使用C#实现Excel与DataTable互转指南

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


实现方案详解

方法一:Excel→DataTable

实现步骤

  1. 加载Excel文件 :使用Workbook类加载文件
  2. 选择工作表:指定目标Sheet索引或名称
  3. 转换逻辑 :通过ExportDataTable()方法提取数据
csharp 复制代码
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()批量写入
ini 复制代码
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)开启高效开发。

相关推荐
Fency咖啡18 分钟前
Spring 基础核心 - SpringMVC 入门与请求流程
java·后端·spring·mvc
阑梦清川1 小时前
深入理解文件系统和软硬链接
后端
Cache技术分享1 小时前
204. Java 异常 - Error 类:表示 Java 虚拟机中的严重错误
前端·后端
闲人编程2 小时前
使用Django从零开始构建一个个人博客系统
后端·python·django·接口·restful·web·个人博客
做运维的阿瑞2 小时前
从入门到精通:Django的深度探索之旅
开发语言·后端·python·系统架构·django
Penge6663 小时前
Go语言中的切片展开操作符 ...
后端·go
用户4099322502123 小时前
银行转账不白扣钱、电商下单不超卖,PostgreSQL事务的诀窍是啥?
后端·ai编程·trae
懒惰蜗牛3 小时前
Day27 | Java集合框架之List接口详解
java·后端·java-ee·list
武子康4 小时前
大数据-114 Flink DataStreamAPI 从 SourceFunction 到 RichSourceFunction 源函数的增强与实战
大数据·后端·flink
月疯4 小时前
FLASK与JAVA的文件互传(单文件互传亲测)
后端·python·flask