使用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)开启高效开发。

相关推荐
码事漫谈3 小时前
当AI开始“思考”:我们是否真的准备好了?
前端·后端
铁东博客5 小时前
Go实现周易大衍筮法三变取爻
开发语言·后端·golang
oak隔壁找我5 小时前
SpringBoot中MyBatis的Mapper的原理
后端
oak隔壁找我6 小时前
Spring Boot 自动配置(Auto-configuration)的核心原理
后端
oak隔壁找我6 小时前
Java的JAR包
后端
GetcharZp6 小时前
告别 TCP 握手延迟!让你的 Go 服务瞬间拥抱 HTTP/3 时代
后端
oak隔壁找我6 小时前
SpringBoot 将项目打包成 Fat JAR(肥包),核心原理
后端
IT_陈寒8 小时前
为什么我的Vite热更新老是重新加载整个页面?
前端·人工智能·后端
还在忙碌的吴小二8 小时前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring