C#实现将Excel表格转换为DataTable

 更新时间:2026年01月21日 15:29:11   作者:m5655bj  
在企业级开发中,Excel 与数据库 / 内存数据集的互转是高频需求,DataTable 作为.NET 中通用的内存数据结构,常被用于承接 Excel 数据进行后续处理,下面我们就来看看如何使用C#实现二者间的转换吧

在企业级开发中,Excel 与数据库 / 内存数据集的互转是高频需求,DataTable 作为.NET 中通用的内存数据结构,常被用于承接 Excel 数据进行后续处理(如数据验证、入库、展示)。本文将分享如何使用免费库 Free Spire.XLS for .NET 实现 Excel 文件到 DataTable 的高效转换。

一、免费库介绍与安装

1. Free Spire.XLS for .NET 核心优势

内置 ExportDataTable 方法,无需手动遍历单元格,代码量减少80%;

无需依赖 Microsoft Office/Excel 客户端,跨平台部署更便捷;

支持 .xls、.xlsx 等主流 Excel 格式,API封装直观,新手易上手。

注意: 免费版有一定数据量限制,适合小型项目

2. 安装 Free Spire.XLS

推荐通过NuGet快速安装,步骤如下:

  • 右键项目 → 管理NuGet程序包;
  • 搜索“Free Spire.XLS”并安装最新稳定版;

或在 Package Manager Console 执行命令:

Install-Package FreeSpire.XLS

二、核心实现:Excel 转 DataTable

1. 将指定工作表转换为 DataTable 内存数据集

以下代码实现最核心的转换逻辑,包含 “加载 Excel→选取目标工作表→核心数据转DataTable→验证并输出结果” 完整流程:

using Spire.Xls;
using System;
using System.Data;

namespace ExcelToDataTableDemo
{
    class Program
    {
        static void Main()
        {
            // 定义Excel文件路径
            string excelFilePath = "Sample.xlsx";

            // 1. 初始化Workbook并加载Excel文件
            Workbook workbook = new Workbook();
            workbook.LoadFromFile(excelFilePath);

            // 2. 获取第一个工作表(索引从0开始)
            Worksheet sheet = workbook.Worksheets[0];

            // 3. 核心:调用内置ExportDataTable方法转换
            // 参数1:要导出的单元格范围(AllocatedRange表示工作表的有效数据范围)
            // 参数2:是否将第一行作为DataTable的列名
            DataTable dataTable = sheet.ExportDataTable(sheet.AllocatedRange, true);

            // 4. 验证转换结果:输出数据信息
            Console.WriteLine("=== Excel转DataTable结果 ===");
            // 输出总行数(排除表头)
            Console.WriteLine($"数据总行数:{dataTable.Rows.Count}");
            // 输出列名
            Console.Write("列名:");
            foreach (DataColumn col in dataTable.Columns)
            {
                Console.Write(col.ColumnName + "\t");
            }
            Console.WriteLine("\n=== 数据内容 ===");
            // 输出所有行数据
            foreach (DataRow row in dataTable.Rows)
            {
                foreach (var cellValue in row.ItemArray)
                {
                    Console.Write(cellValue + "\t");
                }
                Console.WriteLine();
            }
        }
    }
}

2. 进阶用法:自定义转换范围与参数

ExportDataTable 提供了多个重载方法,可满足“指定转换范围、是否导出空值”等个性化需求,以下是常用进阶场景:

场景1:只转换指定行/列范围(如第2-10行、第1-3列)

// 获取指定范围的单元格(行/列索引均从1开始)
CellRange targetRange = sheet.Range["A2:C10"];
// 转换指定范围,且不将第一行作为列名(因范围从第2行开始)
DataTable dataTable = sheet.ExportDataTable(targetRange, false);

场景2:导出时计算公式值

// 重载方法:第三个参数控制是否计算公式值。
// 参数说明:
// range:转换范围
// exportColumnNames:是否将第一行作为列名
// computedFormulaValue:是否计算公式值
DataTable dataTable = sheet.ExportDataTable(
    sheet.AllocatedRange, 
    true,  
    true
);

通过本文的 ExportDataTable 方法,一行代码即可完成核心Excel 到 DataTable 的转换,无需手动遍历单元格。

到此这篇关于C#实现将Excel表格转换为DataTable的文章就介绍到这了,更多相关C# Excel转DataTable内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Unity制作小地图和方向导航

    Unity制作小地图和方向导航

    这篇文章主要为大家详细介绍了Unity制作小地图和方向导航的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • WinForm实现的图片拖拽与缩放功能示例

    WinForm实现的图片拖拽与缩放功能示例

    这篇文章主要介绍了WinForm实现的图片拖拽与缩放功能,结合具体实例形式分析了WinForm鼠标事件响应及图片元素动态操作相关实现技巧,需要的朋友可以参考下
    2017-05-05
  • 一文 详解C#正确使用异常的六大原则

    一文 详解C#正确使用异常的六大原则

    编程的世界充满了挑战和乐趣,异常就是我们绕不过去的大石头,有时候,我们需要主动引发一些异常,有时候,又需要主动捕捉一些异常,今天,我们就来聊聊六个关于异常使用的黄金法则,帮助你在这个充满挑战的领域中游刃有余,需要的朋友可以参考下
    2025-12-12
  • C#多线程系列之线程通知

    C#多线程系列之线程通知

    本文详细讲解了C#多线程中的线程通知,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Unity 实现给物体替换材质球

    Unity 实现给物体替换材质球

    这篇文章主要介绍了Unity 实现给物体替换材质球的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • winform使用委托和事件来完成两个窗体之间通信的实例

    winform使用委托和事件来完成两个窗体之间通信的实例

    这篇文章介绍了winform使用委托和事件来完成两个窗体之间通信的实例,有需要的朋友可以参考一下
    2013-09-09
  • C#实现获取程序路径方法小结

    C#实现获取程序路径方法小结

    这篇文章主要介绍了C#实现获取程序路径方法,实例分析了C#获取文件路径的各种常用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • 详解C#枚举中使用Flags特性

    详解C#枚举中使用Flags特性

    这篇文章主要介绍了C#枚举中使用Flags特性的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C#实现绑定DataGridView与TextBox之间关联的方法

    C#实现绑定DataGridView与TextBox之间关联的方法

    这篇文章主要介绍了C#实现绑定DataGridView与TextBox之间关联的方法,涉及C#绑定控件关联性的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • 基于C#实现简单的二维码和条形码的生成工具

    基于C#实现简单的二维码和条形码的生成工具

    这篇文章主要为大家详细介绍了如何基于C#实现简单的二维码和条形码工具,用于二维码条形码的生成与识别,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12

最新评论