C#测试Excel开源组件ExcelDataReader

使用微软的com组件Microsoft.office.Interop.Excel读写Excel文件虽然可用,但是列多、行多的时候速度很慢,之前测试过Sylvan.Data.Excel包的用法,如果只是读取Excel文件内容的话,还可以使用ExcelDataReader包,后者是C#开源、轻量化、快速的Excel文件读取库,支持读取xlsx、xlsb、xls、csv格式的文件。本文学习并测试ExcelDataReader包的基本用法。
  新建Winform项目,在Nuget包管理器中搜索并安装ExcelDataReader。

  ExcelDataReader包中最重要的是ExcelReaderFactory类和IExcelDataReader接口,前者根据不同的文件格式创建对应的数据读取类(也即IExcelDataReader接口实现类),后者用于操作excel文件。IExcelDataReader的常用函数或属性如下:

序号 函数或属性 说明
1 Read 读取当前工作簿中的一行数据
2 NextResult 切换到当前文件的下一工作簿
3 ResultsCount 获取当前文件的工作簿数量
4 FieldCount 返回当前工作簿中的列数量
5 RowCount 返回当前工作簿中的行数量
6 GetValue 获取当前工作簿通过Read函数获取的一行数据中指定列的数据,返回值类型为object,同理还有GetDouble、GetInt32、GetBoolean、GetDateTime、GetString函数,返回指定类型的数据
7 GetColumnWidth 返回列宽,如果列是隐藏状态,则返回 0
8 RowHeight 返回行高 ,如果行是隐藏状态,则返回 0

下方为基本的测试代码,不同于Sylvan.Data.Excel包有专门的函数获取列名,ExcelDataReader需要自己写代码获取列名(其实就是先调用一次Read函数),然后再继续读取下面的数据。

csharp 复制代码
using (var stream = File.Open(txtFileName.Text, FileMode.Open, FileAccess.Read))
{
    using (var reader = ExcelReaderFactory.CreateReader(stream))
    {
        reader.Read();

        for (int i = 0; i < reader.FieldCount; i++)
        {
            DataGridViewTextBoxColumn column = new DataGridViewTextBoxColumn();
            column.HeaderText = reader.GetString(i);
            dgvData.Columns.Add(column);
        }

        while (reader.Read())
        {
            DataGridViewRow dataGridViewRow = new DataGridViewRow();
            dataGridViewRow.CreateCells(dgvData);

            for (int i = 0; i < reader.FieldCount; i++)
            {
                dataGridViewRow.Cells[i].Value = reader.GetValue(i);
            }

            dgvData.Rows.Add(dataGridViewRow);
        }
    }
}

程序运行时遇到下面的报错,百度该错误,找到参考文献3,其中说到要安装System.Text .Encoding.CodePages包,同时在项目的program文件中增加下面的一行代码,照做后问题解决。

csharp 复制代码
static void Main()
{
    ApplicationConfiguration.Initialize();
	//增加下面一行代码
    System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);
    Application.Run(new Form1());
}

最后是程序运行效果,如下图所示:

参考文献:

1\]https://zhuanlan.zhihu.com/p/18555606219 \[2\]https://github.com/ExcelDataReader/ExcelDataReader \[3\]https://blog.csdn.net/qq_41545233/article/details/122198747

相关推荐
张人玉17 分钟前
C#通讯(上位机)常用知识点
开发语言·c#·通讯·上位机开发
武藤一雄2 小时前
C#:nameof 运算符全指南
开发语言·microsoft·c#·.net·.netcore
softbangong3 小时前
815-批量Excel文件合并工具,批量excel文件、工作表合并软件
linux·windows·excel·文件合并·excel合并·数据整理
城数派3 小时前
2000-2024年1km精度人口分布栅格数据(全球/全国/分省/分市)
arcgis·信息可视化·数据分析·excel
城数派4 小时前
1984-2024年中国10米分辨率城市土地利用栅格数据(商业、公服、居住等9类)
arcgis·信息可视化·数据分析·excel
CSharp精选营4 小时前
聊一聊 C# 中的闭包陷阱:foreach 循环的坑你还记得吗?
c#·foreach·循环·for循环
城数派4 小时前
2015-2024年我国1km分辨率逐日地表温度(LST)栅格数据
数据库·arcgis·信息可视化·数据分析·excel
月巴月巴白勺合鸟月半4 小时前
FHIR 的使用
人工智能·c#·fhir
城数派4 小时前
中国全国土壤有机碳密度数据集(2010-2024年)
数据库·arcgis·信息可视化·数据分析·excel
公子小六5 小时前
基于.NET的Windows窗体编程之WinForms控件简介
windows·microsoft·c#·.net