项目介绍

Sylvan.Data.Excel是一个跨平台的.NET库,专注于读取和写入Excel数据文件。支持多种文件格式,并提供高效的数据访问和数据绑定功能。

  • 该库在.NET生态系统中是读取Excel数据文件的最快且内存分配最低的库之一。

使用场景

  • 适用于需要从Excel文件中读取数据并进行进一步处理(如数据分析、报告生成等)的应用程序。
  • 适用于需要将数据从数据库或其他数据源导出到Excel文件的应用程序。

支持的文件格式

  • 读取支持:.xlsx, .xlsb, 和 .xls 格式。
  • 写入支持:.xlsx 和 .xlsb 格式。注意,该库仅支持创建新的Excel文件,不支持编辑或追加到现有文件。

核心组件

  • ExcelDataReader:提供只读、逐行、仅向前的数据访问。它继承自DbDataReader,为访问矩形、表格形数据集提供了一个熟悉的API。它允许通过统一的API访问所有支持的文件格式。
  • ExcelDataWriter:支持将从DbDataReader获取的数据写入到Excel工作表中,支持.xlsx和.xlsb格式。但请注意,它不支持自定义格式、图表或其他常见功能,仅用于导出原始、平面的数据到Excel。

项目特性

    • 高效的数据读取:通过GetStringGetInt32GetDateTime等强类型访问器高效读取数据。
    • 原生Excel数据类型检查GetExcelDataType方法允许检查单元格的原始Excel数据类型,这可能因行而异。
  • 非矩形数据处理RowFieldCount可以返回当前行的字段数,这在处理“锯齿状”、非矩形文件时非常有用。
  • 数据绑定:Sylvan.Data库包含一个通用数据绑定器,可以将DbDataReader绑定到对象,从而轻松地将Excel文件读取为一系列强类型对象。

安装类库

可以通过NuGet包管理器安装Sylvan.Data.Excel库,使用命令Install-Package Sylvan.Data.Excel。

读取原始数据

using Sylvan.Data.Excel;

// ExcelDataReader derives from System.Data.DbDataReader
// The Create method can open .xls, .xlsx or .xlsb files.
using ExcelDataReader edr = ExcelDataReader.Create("data.xls");

do 
{
 var sheetName = edr.WorksheetName;
 // enumerate rows in current sheet.
 while(edr.Read())
 {
  // iterate cells in row.
  // can use edr.RowFieldCount when sheet contains jagged, non-rectangular data
  for(int i = 0; i < edr.FieldCount; i++)
  {
   var value = edr.GetString(i);
  }
  // Can use other strongly-typed accessors
  // bool flag = edr.GetBoolean(0);
  // DateTime date = edr.GetDateTime(1);
  // decimal amt = edr.GetDecimal(2);
 }
 // iterates sheets
} while(edr.NextResult());

将Excel数据绑定到对象

using Sylvan.Data;
using Sylvan.Data.Excel;

using var edr = ExcelDataReader.Create("data.xlsx");
foreach (MyRecord item in edr.GetRecords<MyRecord>())
{
    Console.WriteLine($"{item.Name} {item.Quantity}");
}

class MyRecord
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int? Quantity { get; set; }
    public DateTime Date { get; set; }
}

Excel数据转换为CSV

using Sylvan.Data.Excel;
using Sylvan.Data.Csv;

using var edr = ExcelDataReader.Create("data.xlsx");

do 
{
 var sheetName = edr.WorksheetName;
 using CsvDataWriter cdw = CsvDataWriter.Create("data-" + sheetName + ".csv")
 cdw.Write(edr);
} while(edr.NextResult());

数据写入

ExcelDataWriter 类型用于创建 Excel 工作簿并将 DbDataReader 数据写入工作表。

// *critical* to dispose (using) ExcelDataWriter.
using var edw = ExcelDataWriter.Create("data.xlsx");
DbDataReader dr;
dr = GetQueryResults("UserReport");
edw.Write(dr, "UserReport");
dr = GetQueryResults("SecurityAudit");
edw.Write(dr, "SecurityAudit");
版权声明:
1、本网站名称:帝企吧
2、本站永久网址:https://www.diqiba.com
3、本网站的文章部分内容可能来源于网络及作者投稿,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
4、本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报。
6、本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。
7、本站所有资源来源于互联网,仅用于学习及参考使用,切勿用于商业用途,如产生法律纠纷本站概不负责! 8、资源除标明原创外均来自网络转载,版权归原作者所有,若侵犯到您权益请联系我们删除,我们将及时处理! 9、若您需使用非免费的软件或服务,请购买正版授权并合法使用!