LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

MiniExcel:一个简单高效、低内存的 .NET 处理 Excel 文件的实用类库

admin
2025年6月20日 7:41 本文热度 77

项目介绍

MiniExcel 是一个简单高效的 .NET 处理 Excel 查、写、填充数据的实用工具类库,旨在避免内存溢出(OOM)问题。目前主流框架大多需要将数据全载入到内存方便操作,但这会导致内存消耗问题,MiniExcel 尝试以 Stream 角度写底层算法逻辑,能让原本1000多MB占用降低到几MB,避免内存不够情况。

适用场景

MiniExcel 适用于需要高效处理大量 Excel 数据的各种场景,包括但不限于:

  • 大数据导入导出。
  • Excel 报表生成。
  • 数据分析与处理。
  • Web 应用中的 Excel 文件上传下载。

功能特点

  • 低内存消耗:避免内存溢出(OOM)和频繁的垃圾回收(GC)。
  • 实时行操作:支持对每一行数据进行实时操作。
  • LINQ 延迟执行:支持低消耗、快速分页和其他复杂查询。
  • 轻量级:无需安装 Microsoft Office,无 COM+ 依赖,DLL 大小小于 150KB。
  • 易用 API:提供简洁易用的 API 风格,方便读写和填充 Excel 文件。

主流类库性能对比

读/导入 Excel

Query 查询 Excel 返回强型别 IEnumerable 数据

public class UserAccount
{
    public Guid ID { get; set; }
    public string Name { get; set; }
    public DateTime BoD { get; set; }
    public int Age { get; set; }
    public bool VIP { get; set; }
    public decimal Points { get; set; }
}

var rows = MiniExcel.Query<UserAccount>(path);

// or

using (var stream = File.OpenRead(path))
    var rows = stream.Query<UserAccount>();

查询所有 Sheet 名称跟数据

var sheetNames = MiniExcel.GetSheetNames(path);
foreach (var sheetName in sheetNames)
{
    var rows = MiniExcel.Query(path, sheetName: sheetName);
}

指定单元格开始读取数据

MiniExcel.Query(path,useHeaderRow:true,startCell:"B3")

合并的单元格填充

    var config = new OpenXmlConfiguration()
    {
        FillMergedCells = true
    };
    var rows = MiniExcel.Query(path, configuration: config);

开源地址

https://github.com/mini-software/MiniExcel


阅读原文:原文链接


该文章在 2025/6/20 10:56:35 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved