C#小轮子:MiniExcel,快速操作Excel

文章目录

前言

Excel的操作是我们最常用的操作,Excel相当于一个小型的数据库,目的是为了方便查看。

最近淘到了MiniExcel,简单来说就是特别好用

MiniExcel Github仓库

环境安装

  • Visual Studio 2022
  • .NET Core 6.0
  • Nuget
    • MiniExcel
    • Newtonsoft.Json(方便查看数据)

功能测试

普通读写

普通读写就是列名和实体类完全一致

新建Person测试类

csharp 复制代码
    public class Person
    {

        public string Name { get;set; }

        public int Age { get; set; }

        public string Sex { get; set; }
    }

新建Excel表格

完全一致测试:成功

csharp 复制代码
   static void Main(string[] args)
   {
       //这里填你自己的文件路径
       var res =  MiniExcel.Query<Person>("Resource\\Person.xlsx");

       Console.WriteLine(JsonConvert.SerializeObject(res,Formatting.Indented));
       Console.WriteLine("运行完毕");
       Console.ReadKey();
   }

大小写测试:严格大小写

测试了一下,大小写不通过,必须完全一致。

别名读测试:成功

csharp 复制代码
      [ExcelColumnName("姓名")]
      public string Name { get;set; }

      [ExcelColumnName("年龄")]

      public int Age { get; set; }

      [ExcelColumnName("性别")]

      public string Sex { get; set; }

我懒得重新写数据了,就直接用之前的Excel数据

csharp 复制代码
 var res = new List<T_Person>()
 {
     new T_Person(){
         Name = "小刘",
         Age = 2,
         Sex = "女"
     },
     new T_Person(){
         Name = "小王",
         Age = 4,
         Sex = "男"
     },
     new T_Person(){
         Name = "小陈",
         Age = 5,
         Sex = "女"
     },
 };
 Console.WriteLine(JsonConvert.SerializeObject(res,Formatting.Indented));
 MiniExcel.SaveAs("Resource\\PersonOut2.xlsx",res,true,"Sheet2");

普通写

别名写

内容追加更新

不支持CSV文件内容增加

csharp 复制代码
MiniExcel.Insert("Resource\\Person2.csv", res, "Sheet2");
//不支持插入xlsx
MiniExcel.Insert("Resource\\Person2.xlsx", res, "Sheet2");

建议通过xlsx和csv互转来解决。

csharp 复制代码
MiniExcel.ConvertXlsxToCsv("Resource\\Person.xlsx", "Resource\\Person.csv");

模板写

其它功能

xlsx和CSV互转

csharp 复制代码
MiniExcel.ConvertXlsxToCsv("Resource\\Person.xlsx", "Resource\\Person.csv");
相关推荐
书源丶6 分钟前
三十五、Java 泛型——类型安全的「万能模板」
java·开发语言·安全
EF@蛐蛐堂18 分钟前
【js】浏览器滚动条优化组件OverlayScrollbars
开发语言·javascript·ecmascript
代码中介商1 小时前
C++ 仿函数(Functor)深度解析:从基础到应用
开发语言·c++
小杍随笔1 小时前
Rust桌面GUI框架:性能优化与实战避坑指南
开发语言·性能优化·rust
二哈赛车手1 小时前
新人笔记---项目中简易版的RAG检索后评测指标(@Recall ,Mrr..)实现
java·开发语言·笔记·spring·ai
格林威1 小时前
3D相机视觉检测:环境光太强,结构光点云全是噪点怎么办?
开发语言·人工智能·数码相机·计算机视觉·3d·视觉检测·工业相机
Rust语言中文社区1 小时前
【Rust日报】2026-05-02 Temper - 用 Rust 编写的 Minecraft 服务器项目发布 0.1.0 版
运维·服务器·开发语言·后端·rust
爱滑雪的码农2 小时前
Java基础十一 流(Stream)、文件(File)和IO
java·开发语言·python
叶小鸡2 小时前
Java 篇-项目实战-天机学堂(从0到1)-day11
java·开发语言
格林威2 小时前
线阵工业相机:线阵图像出现“波浪纹”,是机械振动还是编码器问题?
开发语言·人工智能·数码相机·计算机视觉·视觉检测·工业相机·线阵相机