首先说说,第一次遇到过匿名导出的那个时候是在我在北京第一家公司,简单的声明一个对象就可以导出,那时候感觉高大上,自己也想研究研究,但是因为头将代码后来加密了根本看不到。好吧,研究了研究放弃了,后来,因为个人原因离职了。

然后进入了一个外包公司,有个功能需求是导入,导出Excel的需求,当时不想复制粘贴简单操作,也因为受到这家公司动态创建实体的代码上的理解,也不喜欢同事导出时先保存到服务器的逻辑,便用NPOI重写了一份帮助类。

因为时间太长了,更换了电脑,当时测试的Demo已经没有了,我分拆出来一个吧。

实现功能:

注:功能目前只支持单Sheet

导入:支持List和DataTable格式,支持数据非空验证。

导出:支持List和DataTable格式,支持Excel格式,支持匿名类List导出及简单样式操作。

定义Excel和实体类及DataTable的对应列实体,此实体主要是用于帮助定义导入导出时的字段对应关系。

及导入是非空验证,导出时配置简单样式等。

下图是主要类结构图:

ExcelColumn是单元格的列定义的实体类;

ExCelColumns是列的集合定义列。

ExcelStream 是防止NPOI释放操作,因为NPOI2开始至今Response到浏览器会出现错误,后来发现是因为内存释放导致的。

NPOIExelHelper 是导入导出的调用方法。

帮助类的代码不贴了,稍后传上去各位自己下载,因当时开始的考虑与后来的考虑不一致导致代码有部分重复,没有做整理,谅解。

两个导入节点配置,当然你也可以不用配置,那么导入的第一行的单元格直接对应实体类的列或DataTable的表格。

<?xml version="1.0" encoding="utf-8" ?>

<root>

<Inbound>

<!--默认读取节点-->

<row height="20" title="入库SN信息" sheetname="sheet1" ignoreerr="false">

<column key="库房所在地" name="WarehouseName" />

<column key="采购订单号" name="PurchaseNumber"></column>

<column key="批次编号" name="BatchNumber" required="true"></column>

<column key="CODE" name="Code" required="true"></column>

<column key="序列号" name="SN" required="true"></column>

<column key="Configid/Bom" name="ConfigId"></column>

<column key="产品描述" name="ProductDescription"></column>

<column key="入库数量" name="Amount"></column>

</row>

</Inbound>

<Outbound>

<row height="50" title="出库SN信息" sheetname="sheet1" ignoreerr="false">

<column key="库房所在地" name="WarehouseName" />

<column key="出库单号" name="OutBoundNumber" required="true"></column>

<column key="合同号" name="ContractNumber"></column>

<column key="CODE" name="Code" required="true"></column>

<column key="序列号" name="SN" required="true"></column>

<column key="Configid/Bom" name="ConfigId"></column>

<column key="产品描述" name="ProductDescription"></column>

<column key="出库数量" name="Amount"></column>

</row>

</Outbound>

</root>

其中ignoreerr是导入是是否忽略错误导入,一般只是否非空验证错误。

required为此列是否非空验证。

下面我们就做一个导入导出测试。因为本人不喜欢用DataTable,所以DataTable方式不做Demo。但是实体类里面支持Dt导入导出。

首先,声明实体类:

配置导入导出XML:

导入代码:

导出代码:

源码地址:下载链接

NPOI 超简单的导出导入的更多相关文章

  1. poi整合springboot超简单入门例子

    1.导入依赖 2.application.properties只需要数据库连接信息就可以 3.目录结构 有个没用的service,请忽略 4.Controller,因为入门列子,所以简单的导出 导入读 ...

  2. Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)

    <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)> <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)> 目的:指导项 ...

  3. Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)

    <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)> <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)> 目的:指导项 ...

  4. NPOI 在指定单元格导入导出图片

    NPOI 在指定单元格导入导出图片 Intro 我维护了一个 NPOI 的扩展,主要用来导入导出 Excel 数据,最近有网友提出了导入 Excel 的时候解析图片的需求,于是就有了本文的探索 导入E ...

  5. 有史以来功能最全,使用最简单的excel导入/导出工具

    Github地址:https://github.com/xuanbg/Utility. 还有其他一些福利,请各位园友自取. 构造方法 1.用于导出Excel文件 NpoiHelper(ExcelVer ...

  6. php做EXCEL数据导出导入开发的一些小问题

    前两天刚刚做开发CRM系统项目,在做要做EXCEL导出导入功能,因为以前做.NET开发用的是NPOI,但可是没找到PHP版本的,所以就网搜找了个国外的开源PHPEXCEL , 一开始只是做了简单的导入 ...

  7. ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案 try.dot.net 的正确使用姿势 .Net NPOI 根据excel模板导出excel、直接生成excel .Net NPOI 上传excel文件、提交后台获取excel里的数据

    ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案   ASP.NET Core 从2.2版本开始,采用了一个新的名为Endpoint的路由方案,与原来的方案在使用上差别不 ...

  8. SQL SERVER几种数据迁移/导出导入的实践

    SQLServer提供了多种数据导出导入的工具和方法,在此,分享我实践的经验(只涉及数据库与Excel.数据库与文本文件.数据库与数据库之间的导出导入). (一)数据库与Excel 方法1: 使用数据 ...

  9. BCP导出导入大容量数据实践

    前言 SQL SERVER提供多种不同的数据导出导入的工具,也可以编写SQL脚本,使用存储过程,生成所需的数据文件,甚至可以生成包含SQL语句和数据的脚本文件.各有优缺点,以适用不同的需求.下面介绍大 ...

随机推荐

  1. 【25.00%】【vijos P1907】飞扬的小鸟

    描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣告 ...

  2. xshell/putty 连接 linux 虚拟机 connection failed 的解决方案

    ubuntu 默认并没有安装 ssh 服务,如果通过 ssh(XShell/putty) 连接 ubuntu 虚拟机,则需要手动安装 ssh-server(ssh 分客户端和 openssh-clie ...

  3. url操作等

    取得url ?及以前: baseUrl = url.substr(0,url.indexOf('?')+1) searchParam = searchParam.slice(0, -1);//去掉最后 ...

  4. 半监督学习(semi-supervised learning)

    P(x)P(x,y)}⇒P(y|x) 自 P(x) 生成的无标签样本: 自 P(x,y) 生成的标记样本:

  5. 在codefirst迁移的时候 为新增的属性添加一个默认值

    在模型中新增一个属性之后 通过add-migration ConsulationMsg_add_IsDel命令之后 会生成一个 日期+ConsulationMsg_add_IsDel的类文件 打开类文 ...

  6. ude—基于udp的全双工可靠传输协议

    ude是一款基于udp的可靠传输协议,专门用于在数据传输方面对实时性要求较高的应用领域.    tcp协议虽然能保证数据的可靠传输,但它有以下几个缺点:1.tcp的数据确认机制会导致发送方重复发送一些 ...

  7. Linux性能测试 pmap命令

    名称:       pmap - report memory map of a process(查看进程的内存映像信息)用法       pmap [ -x | -d ] [ -q ] pids... ...

  8. ANDROID 中设计模式的採用--结构型模式

            结构型模式中的适配器模式.外观模式.装饰模式.代理模式都属于包装模式,都是对另外的类或对象的包装,仅仅是各自的意图不同. 适配器模式通过对另外的类或对象的包装,将其接口转换为用户期 ...

  9. 中英文对照 —— 互联网、IT(信息科技)、编程

    1. 网站 web-portal:门户网站: 2. 工具与方法 crowdsourcing:众包, crowd ⇒ 众: 3. 软件 MVP:最小化可行产品,Minimum Viable Produc ...

  10. Qt5该插件机制(7)--插件开发演示示例代码(Lower-level API)

    插件代码 接口类的头文件 MyPluginInterface.h #ifndef INTERFACES_H #define INTERFACES_H #include <QtPlugin> ...