C#使用MiniExcel导入导出数据到Excel/CSV文件

2024-02-20 05:20

本文主要是介绍C#使用MiniExcel导入导出数据到Excel/CSV文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MiniExcel简介

简单、高效避免OOM的.NET处理Excel查、写、填充数据工具。

目前主流框架大多需要将数据全载入到内存方便操作,但这会导致内存消耗问题,MiniExcel 尝试以 Stream 角度写底层算法逻辑,能让原本1000多MB占用降低到几MB,避免内存不够情况。

image-20240210212456544

特点:

  • 低内存耗用,避免OOM、频繁 Full GC 情况
  • 支持即时操作每行数据
  • 兼具搭配 LINQ 延迟查询特性,能办到低消耗、快速分页等复杂查询
  • 轻量,不需要安装 Microsoft Office、COM+,DLL小于150KB
  • 简便操作的 API 风格

项目地址:mini-software/MiniExcel: Fast, Low-Memory, Easy Excel .NET helper to import/export/template spreadsheet (support Linux, Mac) (github.com)

image-20240210212654050

安装 MiniExcel

image-20240209130817512

导出数据

 public class Student{public string? Name { get; set; }public string? Home { get; set; }public int? Age {  get; set; }   }//获得当前目录的路径string currentDirectory = Directory.GetCurrentDirectory();//合并当前目录与Excel文件名var path = Path.Combine(currentDirectory, $"{Guid.NewGuid()}.xlsx");List<Student> studentList = new List<Student>(){new Student { Name = "小东", Home = "New York", Age = 25 },new Student { Name = "小西", Home = "London", Age = 22 },new Student { Name = "小南", Home = "Paris", Age = 28 },new Student { Name = "小北", Home = "Tokyo", Age = 24 },new Student { Name = "小王", Home = "Berlin", Age = 26 }};MiniExcel.SaveAs(path, studentList);

导入Excel中如下图所示:

image-20240209131944852

但是目前还不支持Excel的插入:

image-20240209132453019

因此如果遇到不仅仅只是生成Excel,后续还要向Excel添加数据的需求,可以用csv代替:

 //获得当前目录的路径string currentDirectory = Directory.GetCurrentDirectory();//合并当前目录与CSV文件名var path = Path.Combine(currentDirectory, $"{Guid.NewGuid()}.csv");List<Student> studentList = new List<Student>(){new Student { Name = "小东", Home = "New York", Age = 25 },new Student { Name = "小西", Home = "London", Age = 22 },new Student { Name = "小南", Home = "Paris", Age = 28 },new Student { Name = "小北", Home = "Tokyo", Age = 24 },new Student { Name = "小王", Home = "Berlin", Age = 26 }};MiniExcel.SaveAs(path, studentList);

生成的CSV文件如下图所示:

image-20240209132904268

向CSV文件继续添加数据:

  //获得当前目录的路径string currentDirectory = Directory.GetCurrentDirectory();//合并当前目录与Excel文件名//var path = Path.Combine(currentDirectory, $"{Guid.NewGuid()}.csv");var path = Path.Combine(currentDirectory, "10de09bb-ad8c-4430-b717-5f24117a11a6.csv");List<Student> studentList = new List<Student>(){new Student { Name = "小东", Home = "New York", Age = 25 },new Student { Name = "小西", Home = "London", Age = 22 },new Student { Name = "小南", Home = "Paris", Age = 28 },new Student { Name = "小北", Home = "Tokyo", Age = 24 },new Student { Name = "小王", Home = "Berlin", Age = 26 }};//MiniExcel.SaveAs(path, studentList);MiniExcel.Insert(path, studentList);

继续添加数据后的CSV文件如下图所示:

image-20240209133412478

导入数据

 var path = "你的文件路径";var rows = MiniExcel.Query<Student>(path);

实现效果如下所示:

image-20240210214410232
公众号:DotNet学习交流,欢迎您的到来!!

这篇关于C#使用MiniExcel导入导出数据到Excel/CSV文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/727154

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain