SpreadCheetah:高性能的Excel操作处理.NET库

推荐一款高性能.NET库,可用于生成电子表格(Microsoft Excel XLSX)文件。

01 项目简介

SpreadCheetah是一个高性能的.NET库,专注于生成Microsoft Excel XLSX格式的电子表格文件。

该库具有出色的性能,它能够高效地处理大量数据,生成复杂的电子表格文件。

提供了异步API接口、不依赖于Microsoft Excel,支持.NET Standard 2.0及更高版本,包括.NET Framework、.NET Core以及.NET 6和更新的版本。

此外,它还支持Trimmable和NativeAOT兼容性,为开发者提供了更多的部署选项。

02 使用方法

1、安装依赖

复制代码
Install-Package SpreadCheetah

2、示例代码

复制代码
// 引入SpreadCheetah库,用于创建和操作Excel文件  
using SpreadCheetah;  

// 使用MemoryStream来在内存中创建一个数据流,用于存储Excel文件的内容  
using var stream = new MemoryStream();  

// 使用Spreadsheet.CreateNewAsync方法异步创建一个新的Spreadsheet对象,并将其与前面创建的MemoryStream绑定  
// 这个Spreadsheet对象将用于添加数据到Excel文件中  
using (var spreadsheet = await Spreadsheet.CreateNewAsync(stream))  
{  
    // 开始一个新的工作表,命名为"Sheet1"  
    await spreadsheet.StartWorksheetAsync("Sheet1");  

    // 添加一行作为表头,包含"Name", "Age", "City"三个单元格  
    spreadsheet.AddRowAsync(new List<Cell>() { new Cell("Name"), new Cell("Age"), new Cell("City") });  

    // 添加一行数据,包含Alice的信息:姓名、年龄、城市  
    spreadsheet.AddRowAsync(new List<Cell>() { new Cell("Alice"), new Cell("30"), new Cell("New York") });  

    // 添加另一行数据,包含Bob的信息:姓名、年龄、城市  
    spreadsheet.AddRowAsync(new List<Cell>() { new Cell("Bob"), new Cell("25"), new Cell("Los Angeles") });  

    // 完成对当前工作表的编辑,准备将其写入到MemoryStream中  
    await spreadsheet.FinishAsync();  

    // 将MemoryStream中的数据(即Excel文件的内容)写入到磁盘上的文件"example.xlsx"中  
    // File.WriteAllBytes方法将MemoryStream转换为字节数组,并写入指定文件  
    File.WriteAllBytes("example.xlsx", stream.ToArray());  
}

03 项目地址

https://github.com/sveinungf/spreadcheetah

  • End -

我是编程乐趣,一个.Net开发经验老程序员,欢迎"关注"我,每天为你分享开源项目和编程知识。

也欢迎加入【.Net技术编程交流社区】,和大家共同学习交流!,点击加入https://bbs.csdn.net/topics/613465368

推荐阅读

2个零基础入门框架教程!

PDFPatcher:一个无所不能的开源PDF处理工具

Sep:一个低内存、高性能的CSV文件读写操作.Net开源库

openai-dotnet:OpenAI官方提供的.NET SDK库!

TheAlgorithms/C-Sharp:一个包含上百个C#算法示例代码的开源库

相关推荐
小小测试开发26 分钟前
提升App UI自动化性能与效率:从脚本到架构的全链路优化指南
ui·架构·自动化
BW.SU3 小时前
RUI Builder 图形化UI设计工具
ui·hmi·ui设计·ra8889·ra6809·rui·人机界面
用户4488466710606 小时前
.NET进阶——深入理解Lambda表达式(2)手搓LINQ语句
c#·.net
惟恋惜7 小时前
Jetpack Compose 界面元素状态(UI Element State)详解
android·ui·android jetpack
_李小白8 小时前
【Android FrameWork】延伸阅读:IGraphicBufferProducer驱动UI绘制过程
android·ui
ohoy8 小时前
EasyPoi 数据脱敏
开发语言·python·excel
_李小白9 小时前
【Android FrameWork】第二十八天:Activity 的 UI 绘制全过程
android·ui
qq_2052790511 小时前
unity 像素ui的适配问题
ui
惟恋惜11 小时前
Jetpack Compose 多页面架构实战:从 Splash 到底部导航,每个 Tab 拥有独立 ViewModel
android·ui·架构·android jetpack
开开心心_Every12 小时前
Word转PDF工具,免费生成图片型文档
网络·笔记·pdf·word·powerpoint·excel·azure