ExcelToObject.NPOI 两行代码导出Excel报表、读取Excel数据
简介
作为一个dotnet开发者,经常面对业务系统中大量报表导入导出,经常写了一堆的重复代码。最近发现一个操作excel的神器:ExcelToObject.NPOI,两行代码就能导出一个报表,两行代码就能读取excel数据。就像作者说的:让操作excel变成了操作对象。下面让我们来看看这个组件
项目地址:
https://gitee.com/fengwuyan/ExcelToObject
项目示例
- 在项目中引入
ExcelToObject.NPOI
dotnet add package ExcelToObject.Npoi --version 1.0.0
- 在Program或Startup类中添加服务
service.AddExcelToObjectNpoiService();
以下以一个业务来举例,一个导入业务需要同时导入两个数据源,我们先把Excel模板定义好。
第一个Sheet页:导入基本信息

第二个Sheet页:导入字典配置信息列表

以下为导入两个数据sheet的代码
- 构造函数注入
IExcelFactory对象 - 使用
ReadByNameManager和ReadListByNameManager方法分别读取单个对象和读取list列表
- 构造函数注入
private readonly IExcelFactory _excelFactory;
public FileAppService(IExcelFactory excelFactory)
{
_excelFactory = excelFactory;
}
public Task ImportAsync(Stream fileStream)
{
using var excelService = _excelFactory.Create(fileStream);
var userImportInput = excelService.ReadByNameManager<UserImportExportDto>("基本信息");
var settingImportInputList = excelService.ReadListByNameManager<SettingImportExportDto>("字典配置");
Console.WriteLine($"姓名:{userImportInput.Name}、年龄:{userImportInput.Age}");
settingImportInputList.ForEach(e => Console.WriteLine($"类别名称:{e.CategoryName}、字典项名称:{e.ItemName}、字典项值:{e.Value}"));
//写入到数据库
}
详细操作
- 分别定义对应数据Sheet页的DTO
- 人员信息dto
/// <summary>
/// 用户导入导出dto
/// </summary>
public class UserImportExportDto
{
/// <summary>
/// 姓名
/// </summary>
public string Name { get; set; }
/// <summary>
/// 年龄
/// </summary>
public int Age { get; set; }
/// <summary>
/// 性别
/// </summary>
public string Gender { get; set; }
/// <summary>
/// 身份证号
/// </summary>
public string IDCard { get; set; }
/// <summary>
/// 毕业院校
/// </summary>
public string School { get; set; }
/// <summary>
/// 简介
/// </summary>
public string Profile { get; set; }
}
- 字典配置信息dto
/// <summary>
/// 字典配置
/// </summary>
public class SettingImportExportDto
{
/// <summary>
/// 字典类别编码
/// </summary>
public string CategoryCode { get; set; }
/// <summary>
/// 字典类别名称
/// </summary>
public string CategoryName { get; set; }
/// <summary>
/// 字典项编码
/// </summary>
public string ItemCode { get; set; }
/// <summary>
/// 字典项名称
/// </summary>
public string ItemName { get; set; }
/// <summary>
/// 字典值
/// </summary>
public string Value { get; set; }
/// <summary>
/// 备注
/// </summary>
public string Remark { get; set; }
}
设置Excel模板内每个Sheet的名称管理器,名称管理器的值与DTO的属性名称一致
- 人员信息


最终每个对应的数据区都配置好了名称管理器之后的效果:

- 字典配置信息


配置好之后,就可以了。总结就两步:
- 定义导入导出dto
- 配置excel模板的名称管理器
写入操作
写入操作也是一样的流程
- 建立对应DTO
- 配置excel模板
- 调用
WriteByNameManager和WriteListByNameManager方法写入数据到对应Sheet,调用Write写入到excel文件。
public async Task<string> ExportAsync()
{
var userDto = new UserImportExportDto();
var settingDtoList = new List<SettingImportExportDto>();
var excelTemplateFilePath = "";
using var excelService = _excelFactory.Create(File.Open(excelTemplateFilePath, FileMode.Open, FileAccess.Read));
excelService.WriteByNameManager(userDto, "基本信息");
excelService.WriteListByNameManager(settingDtoList, "字典配置");
var resultFileSavePath = "";
excelService.Write(File.Open(resultFileSavePath, FileMode.OpenOrCreate, FileAccess.ReadWrite));
return resultFileSavePath;
}
总结
ExcelToObject.NPOI两行代码导出excel报表及读取数据,是通过每个sheet页内的名称管理器的值与对应代码中的类的属性名称相同,从而进行匹配,达到智能读取的功能
ExcelToObject.NPOI 两行代码导出Excel报表、读取Excel数据的更多相关文章
- C#操作Excel文件(读取Excel,写入Excel)
看到论坛里面不断有人提问关于读取excel和导入excel的相关问题.闲暇时间将我所知道的对excel的操作加以总结,如今共享大家,希望给大家可以给大家带了一定的帮助.另外我们还要注意一些简单的问题1 ...
- NPOI 导入Excel和读取Excel
1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet:行:Row:单元格Cell. 2.NPOI是POI的C#版本,NPOI的行和列的index都是从0开始 ...
- NPOI操作excel之读取excel数据
NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目. 一.下载引用 去NPOI官网http://npoi.codeplex. ...
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
1.引用Microsoft.Office.Interop.Excel.dll 2.引用命名空间.使用别名 using System.Reflection; using Excel = Microsof ...
- SpringBoot(十三)_springboot上传Excel并读取excel中的数据
今天工作中,发现同事在整理数据,通过excel上传到数据库.所以现在写了篇利用springboot读取excel中的数据的demo.至于数据的进一步处理,大家肯定有不同的应用场景,自行修改 pom文件 ...
- jxl读写excel, poi读写excel,word, 读取Excel数据到MySQL
这篇blog是介绍: 1. java中的poi技术读取Excel数据,然后保存到MySQL数据中. 2. jxl读写excel 你也可以在 : java的poi技术读取和导入Excel了解到写入Exc ...
- ThinkPHP3.2.3使用PHPExcel类操作excel导入读取excel
方法一: 1. 下载PHPExcel并保存在如下位置: 2. 在控制器中引用 vendor("PHPExcel.PHPExcel"); $objReader = \PHPExcel ...
- POI导入excel时读取excel数据的真实行数
有很多时候会出现空的数据导致行数被识别多的情况 // 获取Excel表的真实行数 int getExcelRealRow(Sheet sheet) { boolean flag = false; fo ...
- NPOI复制模板导出Excel
本人菜鸟实习生一枚,公司给我安排了一个excel导出功能.要求如下:1.导出excel文件有样式要求:2.导出excel包含一个或多个工作表:3.功能做活(我的理解就是excel样式以后可能会变方便维 ...
- php读取excel文件的实例代码
php读取excel文件的实例代码. 代码: <?php /** * php读取excel文件 * by www.jbxue.com */ $this->loadexcel();//半酣p ...
随机推荐
- Fluentd部署:错误排查
介绍一下排查Fluentd运行时错误的几种方法. 查看日志 如果感觉Fluentd运行异常,请先查看日志.td-agent安装后,默认日志存放在/var/log/td-agent/td-agent.l ...
- 1-VSCode搭建GD32开发环境
一.使用VSCode开发GD32的原因 1-单片机开发用的最多的IDE为Keil,而Keil为商用软件,并非开源,而且只支持windows环境,介于当前关系,有断供的风险在. 2-其他IDE类似第1条 ...
- 【强烈推荐】用glob库的一行命令显著加速批量读取处理数据
在我们气象领域,对数据进行批处理随处可见,尤其是在处理模式数据的时候.为了能让这个过程加速,很多大佬们提出了不同的方法,比如使用numba库进行计算.使用dask库进行并行等等,都是非常好的加速手段. ...
- 1.2.2 musl pwn
1.2.2 musl pwn 几个结构 __malloc_context(与glibc中的main_arena类似) struct malloc_context { uint64_t secret; ...
- 齐博X1-栏目的调用1
本节来说明下系统提供的几个栏目调用的方法 一节我们制作了一个公共导航,本节我们在首页index中演示下栏目的相关调用 至于其他的数据内容,参考第二季的标签调用即可,直接{qb:tag}调用就可以调用出 ...
- SQL--存储过程的使用
存储过程的概念 存储过程类似一个函数,可以执行一条或者多条SQL语句,可带参数,可返回值 为了简化操作,方便更改和扩展,将一个事件的处理封装在一个单元中供使用. 创建存储过程 --创建存储过程(不带参 ...
- Salesforce LWC学习(四十) dynamic interaction 浅入浅出
本篇参考: Configure a Component for Dynamic Interactions in the Lightning App Builder - Salesforce Light ...
- FlinkSQL之Windowing TVF
Windowing TVF 在Flink1.13版本之后出现的替代之前的Group window的产物,官网描述其 is more powerful and effective //TVF 中的tu ...
- JS逆向实战7-- 某省在线审批网站params 随机生成
参数分析 我们首先通过抓包 发现这个就是我们所需要的数据 然后我们通过fidder 发起请求 结果: 通过我们反复测试 发现这个params的参数是每次请求中都会变化的 断点查找 我们通过 这个t参数 ...
- 2022HNCTF--WEB
@ 目录 [Week1]Interesting_http 分析 payload [Week1]2048 分析 payload [Week1]easy_html 分析 paylaod [Week1]In ...