MiniExcel 1.35.0
Prefix Reserveddotnet add package MiniExcel --version 1.35.0
NuGet\Install-Package MiniExcel -Version 1.35.0
<PackageReference Include="MiniExcel" Version="1.35.0" />
paket add MiniExcel --version 1.35.0
#r "nuget: MiniExcel, 1.35.0"
// Install MiniExcel as a Cake Addin #addin nuget:?package=MiniExcel&version=1.35.0 // Install MiniExcel as a Cake Tool #tool nuget:?package=MiniExcel&version=1.35.0
This project is part of the .NET Foundation and operates under their code of conduct.
Introduction
MiniExcel is simple and efficient to avoid OOM's .NET processing Excel tool.
At present, most popular frameworks need to load all the data into the memory to facilitate operation, but it will cause memory consumption problems. MiniExcel tries to use algorithm from a stream to reduce the original 1000 MB occupation to a few MB to avoid OOM(out of memory).
Features
- Low memory consumption, avoid OOM (out of memory) and full GC
- Support
real-time
operation of each row of data - Support LINQ deferred execution, it can do low-consumption, fast paging and other complex queries
- Lightweight, without Microsoft Office installed, no COM+, DLL size is less than 150KB
- Easy API style to read/write/fill excel
Get Started
Installation
You can install the package from NuGet
Release Notes
Please Check Release Notes
TODO
Please Check TODO
Performance
Benchmarks logic can be found in MiniExcel.Benchmarks , and test cli
dotnet run -p .\benchmarks\MiniExcel.Benchmarks\ -c Release -f netcoreapp3.1 -- -f * --join
Output from the latest run is :
BenchmarkDotNet=v0.12.1, OS=Windows 10.0.19042
Intel Core i7-7700 CPU 3.60GHz (Kaby Lake), 1 CPU, 8 logical and 4 physical cores
[Host] : .NET Framework 4.8 (4.8.4341.0), X64 RyuJIT
Job-ZYYABG : .NET Framework 4.8 (4.8.4341.0), X64 RyuJIT
IterationCount=3 LaunchCount=3 WarmupCount=3
Benchmark History : Link
Import/Query Excel
Logic : Test1,000,000x10.xlsx as performance test basic file, 1,000,000 rows * 10 columns "HelloWorld" cells, 23 MB file size
Library | Method | Max Memory Usage | Mean |
---|---|---|---|
MiniExcel | 'MiniExcel QueryFirst' | 0.109 MB | 0.0007264 sec |
ExcelDataReader | 'ExcelDataReader QueryFirst' | 15.24 MB | 10.66421 sec |
MiniExcel | 'MiniExcel Query' | 17.3 MB | 14.17933 sec |
ExcelDataReader | 'ExcelDataReader Query' | 17.3 MB | 22.56508 sec |
Epplus | 'Epplus QueryFirst' | 1,452 MB | 18.19801 sec |
Epplus | 'Epplus Query' | 1,451 MB | 23.64747 sec |
OpenXmlSDK | 'OpenXmlSDK Query' | 1,412 MB | 52.00327 sec |
OpenXmlSDK | 'OpenXmlSDK QueryFirst' | 1,413 MB | 52.34865 sec |
ClosedXml | 'ClosedXml QueryFirst' | 2,158 MB | 66.18897 sec |
ClosedXml | 'ClosedXml Query' | 2,184 MB | 191.43412 sec |
Export/Create Excel
Logic : create a total of 10,000,000 "HelloWorld" excel
Library | Method | Max Memory Usage | Mean |
---|---|---|---|
MiniExcel | 'MiniExcel Create Xlsx' | 15 MB | 11.53181 sec |
Epplus | 'Epplus Create Xlsx' | 1,204 MB | 22.50971 sec |
OpenXmlSdk | 'OpenXmlSdk Create Xlsx' | 2,621 MB | 42.47399 sec |
ClosedXml | 'ClosedXml Create Xlsx' | 7,141 MB | 140.93992 sec |
Documents
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net45 is compatible. net451 was computed. net452 was computed. net46 was computed. net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.5
- No dependencies.
-
.NETStandard 2.0
- No dependencies.
-
net8.0
- No dependencies.
NuGet packages (105)
Showing the top 5 NuGet packages that depend on MiniExcel:
Package | Downloads |
---|---|
GuoKun.CPS
国坤CPS库 |
|
DH.MiniExcel
DH框架的Excel处理库。基于https://github.com/mini-software/MiniExcel |
|
NF.Utilities
公共类库,增加DataTable转excel |
|
BootstrapBlazor.TableExport
Bootstrap UI components extensions of export |
|
TXQ.Utils
Package Description |
GitHub repositories (9)
Showing the top 5 popular GitHub repositories that depend on MiniExcel:
Repository | Stars |
---|---|
Scighost/Starward
Game Launcher for miHoYo - 米家游戏启动器
|
|
dotnetcore/BootstrapBlazor
Bootstrap Blazor is an enterprise-level UI component library based on Bootstrap and Blazor.
|
|
dotnetcore/Magicodes.IE
Import and export general library, support Dto import and export, template export, fancy export and dynamic export, support Excel, Csv, Word, Pdf and Html.
|
|
izhaorui/Zr.Admin.NET
🎉ZR.Admin.NET是一款前后端分离的、跨平台基于RBAC的通用权限管理后台。ORM采用SqlSugar。前端采用Vue、AntDesign,支持多租户、缓存、任务调度、支持统一异常处理、接口限流、支持一键生成前后端代码,支持动态国际化翻译(Vue3),等诸多黑科技,代码简洁易懂、易扩展让开发更简单、更通用。
|
|
xunkong/xunkong
记录旅途中发生的事
|
Version | Downloads | Last updated | |
---|---|---|---|
1.35.0 | 5,236 | 11/9/2024 | |
1.34.2 | 79,154 | 9/14/2024 | |
1.34.1 | 71,330 | 8/10/2024 | |
1.34.0 | 48,629 | 7/21/2024 | |
1.33.0 | 45,845 | 7/7/2024 | |
1.32.1 | 96,686 | 5/16/2024 | |
1.32.0 | 16,702 | 5/12/2024 | |
1.31.3 | 385,405 | 12/27/2023 | |
1.31.2 | 574,673 | 8/10/2023 | |
1.31.0 | 232,518 | 5/28/2023 | |
1.30.3 | 87,975 | 5/1/2023 | |
1.30.2 | 424,432 | 2/21/2023 | |
1.30.1 | 33,973 | 2/7/2023 | |
1.30.0 | 189,990 | 12/27/2022 | |
1.29.0 | 185,299 | 11/9/2022 | |
1.28.5 | 19,301 | 10/30/2022 | |
1.28.4 | 3,055 | 10/29/2022 | |
1.28.2 | 3,040 | 10/29/2022 | |
1.28.1 | 24,877 | 10/22/2022 | |
1.28.0 | 67,673 | 9/19/2022 | |
1.27.0 | 3,813 | 9/18/2022 | |
1.26.7 | 11,061 | 9/9/2022 | |
1.26.6 | 10,544 | 9/4/2022 | |
1.26.5 | 293,354 | 6/30/2022 | |
1.26.4 | 6,631 | 6/26/2022 | |
1.26.3 | 227,050 | 6/7/2022 | |
1.26.2 | 192,907 | 4/21/2022 | |
1.26.1 | 10,407 | 4/17/2022 | |
1.26.0 | 218,410 | 4/12/2022 | |
1.24.2 | 3,349 | 3/17/2022 | |
1.24.1 | 4,887 | 3/15/2022 | |
1.24.0 | 14,937 | 3/9/2022 | |
1.23.2 | 7,455 | 3/4/2022 | |
1.23.1 | 226,025 | 2/14/2022 | |
1.22.0 | 3,315 | 2/12/2022 | |
0.21.5 | 31,937 | 2/7/2022 | |
0.21.4 | 8,458 | 1/27/2022 | |
0.19.1 | 277,589 | 11/15/2021 | |
0.19.0 | 12,934 | 10/21/2021 | |
0.18.0 | 16,338 | 9/13/2021 | |
0.17.5 | 247,430 | 8/20/2021 | |
0.17.4 | 5,120 | 8/17/2021 | |
0.17.2 | 252,312 | 6/30/2021 | |
0.17.1 | 6,273 | 6/23/2021 | |
0.17.0 | 6,042 | 6/21/2021 | |
0.16.1 | 4,576 | 6/19/2021 | |
0.16.0 | 3,313 | 6/19/2021 | |
0.15.5 | 4,931 | 6/13/2021 | |
0.15.4 | 3,487 | 6/8/2021 | |
0.15.2 | 10,118 | 5/20/2021 | |
0.15.1 | 3,236 | 5/19/2021 | |
0.14.8 | 3,693 | 5/18/2021 | |
0.14.7 | 3,507 | 5/17/2021 | |
0.14.6 | 4,697 | 5/13/2021 | |
0.14.5 | 3,645 | 5/12/2021 | |
0.14.4 | 3,245 | 5/12/2021 | |
0.14.3 | 4,771 | 5/10/2021 | |
0.14.2 | 3,229 | 5/10/2021 | |
0.14.1 | 4,637 | 5/7/2021 | |
0.14.0 | 3,313 | 5/7/2021 | |
0.13.5 | 4,901 | 4/30/2021 | |
0.13.4 | 5,292 | 4/26/2021 | |
0.13.3 | 5,443 | 4/22/2021 | |
0.13.2 | 4,932 | 4/20/2021 | |
0.13.1 | 3,389 | 4/18/2021 | |
0.13.0 | 3,194 | 4/16/2021 | |
0.12.2 | 3,100 | 4/15/2021 | |
0.12.1 | 3,012 | 4/14/2021 | |
0.12.0-beta | 2,245 | 4/13/2021 | |
0.11.1 | 4,501 | 4/9/2021 | |
0.11.0 | 3,116 | 4/8/2021 | |
0.10.3 | 3,098 | 4/6/2021 | |
0.10.2 | 3,047 | 4/6/2021 | |
0.10.1 | 3,089 | 4/4/2021 | |
0.10.0 | 3,073 | 4/2/2021 | |
0.9.1 | 3,120 | 4/1/2021 | |
0.9.0 | 3,020 | 4/1/2021 | |
0.8.0 | 3,298 | 3/29/2021 | |
0.7.0 | 3,080 | 3/28/2021 | |
0.6.0 | 3,088 | 3/26/2021 | |
0.5.0 | 3,044 | 3/26/2021 | |
0.4.0 | 3,062 | 3/25/2021 | |
0.3.0 | 3,029 | 3/21/2021 | |
0.2.3 | 3,145 | 3/20/2021 | |
0.2.2 | 3,375 | 3/18/2021 | |
0.2.1 | 3,278 | 3/17/2021 | |
0.2.0 | 3,314 | 3/15/2021 | |
0.1.0-preview | 2,427 | 3/15/2021 | |
0.0.7-beta | 2,414 | 3/14/2021 | |
0.0.6-beta | 2,443 | 3/14/2021 | |
0.0.5-beta | 2,543 | 3/14/2021 | |
0.0.4-beta | 2,441 | 3/14/2021 | |
0.0.3-beta | 2,410 | 3/13/2021 | |
0.0.2-beta | 2,367 | 3/4/2021 | |
0.0.1-beta | 2,357 | 3/3/2021 |
Please Check [Release Notes](https://github.com/mini-software/MiniExcel/tree/master/docs)