前言
在處理數據分析和報表自動化時,讀取Microsoft Excel文件是一個常見需求。今天,我們推薦一個功能強大且易于使用的開源庫——ExcelDataReader,它專門用于高效讀取Excel文件數據。
項目簡介:ExcelDataReader是一個.NET下的開源項目,提供了簡單而豐富的API來讀取Excel文件。它特別適合處理大數據量的Excel文件,同時保持了高效的性能。
支持的Excel版本和格式
Excel 2007至2021
Office 365的Excel格式
支持的文件格式包括`.xls`, `.xlsx`, `.xlsm`, `.xltx`, `.xlsb`, 和`.xml`。
支持的.NET版本
.NET Framework 4.6及以上
.NET Standard 2.0
.NET Core 5及以上
使用方法
1. 安裝依賴庫
通過NuGet包管理器安裝ExcelDataReader:
```shell
Install-Package ExcelDataReader
```
2. 示例代碼
以下是一個使用ExcelDataReader讀取Excel文件的基本示例:
```csharp
using ExcelDataReader;
using System.Text; // .Net Core必須注冊
// 注冊代碼頁提供程序
Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
// 打開文件流
using (var stream = File.Open("f:/demo.xls", FileMode.Open, FileAccess.Read))
{
// 獲取Excel閱讀器
using (var reader = ExcelReaderFactory.CreateReader(stream))
{
// 逐行讀取數據
while (reader.Read())
{
Console.WriteLine($"單元格1:{reader.GetString(0)},單元格2:{reader.GetDouble(1)}");
}
// 移動到下一個結果(如果有)
while (reader.NextResult());
}
}
```
注冊代碼頁提供程序:對于.NET Core項目,需要注冊`CodePagesEncodingProvider`以支持舊的編碼。
打開文件流:使用`File.Open`方法以讀取模式打開Excel文件。
創建Excel閱讀器:使用`ExcelReaderFactory.CreateReader`方法從文件流創建一個閱讀器。
逐行讀取:使用`reader.Read()`方法逐行讀取Excel文件中的數據。
獲取單元格數據:使用`reader.GetString(int columnIndex)`和`reader.GetDouble(int columnIndex)`等方法獲取特定列的數據。
項目地址:想要獲取更多關于ExcelDataReader的信息或下載源代碼,請訪問其GitHub倉庫:[ExcelDataReader GitHub倉庫](https://github.com/ExcelDataReader/ExcelDataReader)
ExcelDataReader作為一個高性能的Excel讀取庫,極大地簡化了.NET項目中處理Excel文件的復雜性。希望本文能幫助您快速上手ExcelDataReader,提升數據處理的效率。
該文章在 2024/8/8 5:36:00 編輯過