【 C# 使用 MiniExcel 库的典型场景】

以下是 C# 使用 MiniExcel 库的典型场景及代码示例:

一、基础读取操作

强类型读取‌(需定义数据模型类)

定义与 Excel 列名匹配的类后直接映射为对象集合:

csharp

Copy Code

public class UserAccount {

public int Id { get; set; }

public string Name { get; set; }

}

var data = MiniExcel.Query("example.xlsx").ToList();

foreach (var item in data)

Console.WriteLine($"ID:{item.Id}, Name:{item.Name}");

适用场景:列结构固定的 Excel 文件‌。

动态类型读取‌

无需定义模型,通过列名(如 A, B)或列名属性访问数据:

csharp

Copy Code

var rows = MiniExcel.Query("test.xlsx").ToList();

foreach (var row in rows)

Console.WriteLine($"第一列值:{row.A},第二列值:{row.B}");

适用场景:快速读取未知结构或临时 Excel 文件‌。

二、数据写入操作

导出对象集合到 Excel‌

将列表数据写入指定路径的 Excel 文件:

csharp

Copy Code

var users = new List {

new UserAccount { Id = 1, Name = "Alice" },

new UserAccount { Id = 2, Name = "Bob" }

};

MiniExcel.SaveAs("output.xlsx", users);

注:自动根据对象属性生成表头‌。

三、高级处理技巧

数据类型转换‌

动态类型读取时手动转换数据类型:

csharp

Copy Code

var rows = MiniExcel.Query("data.xlsx").ToList();

var processed = rows.Select(r => new {

Id = Convert.ToInt32(r.A),

Score = Convert.ToDouble(r.B)

});

动态类型默认数值为 double,需显式转换‌。

错误处理‌

捕获文件读取异常:

csharp

Copy Code

try {

var data = MiniExcel.Query("invalid.xlsx").ToList();

} catch (FileNotFoundException ex) {

Console.WriteLine(KaTeX parse error: Expected 'EOF', got '}' at position 24: ...ex.Message}"); }̲ catch (Invalid..."格式错误:{ex.Message}");

}

确保程序健壮性‌。

四、性能优化建议

使用流式读取处理百万级数据,避免内存溢出‌。

动态类型读取比强类型更轻量,但牺牲了类型安全性‌。

以上示例覆盖了 MiniExcel 的核心功能,可满足 90% 的 Excel 处理需求‌。

相关推荐
_r0bin_3 小时前
前端面试准备-7
开发语言·前端·javascript·fetch·跨域·class
zhang98800003 小时前
JavaScript 核心原理深度解析-不停留于表面的VUE等的使用!
开发语言·javascript·vue.js
Abigail_chow4 小时前
EXCEL如何快速批量给两字姓名中间加空格
windows·microsoft·excel·学习方法·政务
Fanxt_Ja5 小时前
【JVM】三色标记法原理
java·开发语言·jvm·算法
蓝婷儿5 小时前
6个月Python学习计划 Day 15 - 函数式编程、高阶函数、生成器/迭代器
开发语言·python·学习
绿荫阿广5 小时前
互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(五):使用.NET为树莓派开发Wifi配网功能
c#·.net
love530love5 小时前
【笔记】在 MSYS2(MINGW64)中正确安装 Rust
运维·开发语言·人工智能·windows·笔记·python·rust
slandarer6 小时前
MATLAB | 绘图复刻(十九)| 轻松拿捏 Nature Communications 绘图
开发语言·matlab
狐凄6 小时前
Python实例题:Python计算二元二次方程组
开发语言·python
roman_日积跬步-终至千里6 小时前
【Go语言基础【3】】变量、常量、值类型与引用类型
开发语言·算法·golang