java 导入导出 插件_Java最优的Excel导入/导出工具开发,你用过吗?

cd6cf31e7e1b3cd0e07caaf31e353c6b.png

关注程序员7歌,一起用技术改变世界

在我们实际开发中经常会遇到Excel的导入与导出功能,而目前Excel操作工具也是数不甚数啊,但是7歌用过很多,还是觉得最近发现的tool-excel好用,让你实现一语句代码就能完成Excel功能。

首先我们提供安装依赖:

cn.gjingtools-excel1.1.0

我们先来了解一下tool-excel的注解:

1、@Excel

该注解是使用在类上,表明此类是用来绑定excel的,参数如下:

value:说明excel的文件名,优先级低于方法传入的文件名

type:说明excel的文档类型,默认为XLS

style:说明导出excel的样式

2、@ExcelField

该注解是使用在字段上,表明这是Excel的列表头,参数如下:

value:说明列表头名

pattern:说明时间的转换格式(时间才需要指定)

width:说明列表头的宽度

3、@DateValid

该注解是使用在时间字段的时间校验,表明我这个列表头下指定行数的单元格要进行数据校验,XLSX类型文档不支持,参数如下:

validClass:校验器

ClassboxLastRow:数据校验最多校验多少行,默认是正文第一行

pattern:校验的时间格式,默认yyyy-MM-dd

operatorType:操作类型,默认OperatorType.BETWEEN

expr1:表达式1,默认1970-01-01

expr2:表达式2,默认2999-01-01

showErrorBox:是否弹出错误框,默认true

showPromptBox:是否立即弹出,默认true

allowEmpty:是否允许空值,默认true

rank:提示框级别,默认Rank.WARING警告级别

errorTitle:错误框标题

errorContent:详细错误内容

4、@ExplicitValid

该注解是用来明确范围内容校验的,参数如下:

alidClass:校验器

Classcombobox:范围值,数组类型

boxLastRow:数据校验最多校验多少行,默认是该列表头下的正文第一行

showErrorBox:是否弹出错误框,默认true

rank:提示框级别,默认Rank.WARING警告级别

showPromptBox:是否立即弹出,默认true

errorTitle:错误框标题

errorContent:详细错误内容

5、@NumericValid

该注解用于数据类型的校验,使用在Excel字段上,参数如下:

validClass:校验器

ClassboxLastRow:数据校验最多校验多少行,默认是该列表头下的正文第一行

operatorType:操作类型,默认OperatorType.EQUAL

validationType:校验类型,必填

expr1:表达式1,在表达式2前面,必填

expr2:表达式2,在操作类型为BETWEEN和NOT_BETWEEN情况下必填

showErrorBox:是否弹出错误框,默认true

showPromptBox:是否立即弹出,默认true

allowEmpty:是否允许空值,默认true

rank:提示框级别,默认Rank.WARING警告级别

errorTitle:错误框标题

errorContent:详细错误内容

6、@ExcelEnumConvert

该注解是用于枚举转换,使用在枚举的Excel字段上,参数如下:

convert:实现了EnumConvert接口的类Class

那么我们来看一下tool-excel的具体使用方法:

1、Excel操作实体类:

@Excel(value = "教师评价信息",type = Type.XLS)public class TeacherEvalExcel implements Serializable {private static final long serialVersionUID = -6458620790191821524L;/*** 教师姓名*/@ExcelField("教师姓名")private String teacherName;/*** 当前任教年级*/@ExcelField("当前任教年级")private String gradeNames;/*** 任教科目*/@ExcelField("任教科目")private String courseNames;/*** 评价指标*/@ExcelField("评价指标")private String evalName;/*** 评价项目*/@ExcelField("评价项目")private String evalItemName;/*** 所属学年学期*/@ExcelField("所属学年学期")private String semesterName;/*** 录入时间*/@ExcelField("录入时间")private String inputTime;}

从上面的实体看出,我们加入了@Excel,@ExcelField就可以啦。

2、使用tool-excel实现excel导出功能

/*** 导出教师评价信息* @param pageParamVo* @return* @author zqk*/@PostMapping("/exportExcel")public void exportExcel(@RequestBody PageParamVo pageParamVo){ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletResponse response = servletRequestAttributes.getResponse();PageVo pager = pageParamVo.getPager();pager.setPageSize(-1L);List teacherEvalExcels = teacherEvalService.exportExcelData(new Page<>(pager.getCurrent(), pager.getSize()),pageParamVo.getContent());ExcelFactory.createWriter("教师评价息", TeacherEvalExcel.class, response, teacherEvalExcels).write();}

从上面的代码可以看出,我们实现excel导出就使用了一句代码:

ExcelFactory.createWriter("教师评价息", TeacherEvalExcel.class, response, teacherEvalExcels).write();

如果我们需要导出excel模版,那么我们在wirite()方法里面传入null即可。

3、使用tool-excel实现excel导入功能

/*** 导入教师评价信息* @param file* @return* @throws IOException* @author zqk*/@PostMapping("/importExcel")public Result importExcel(MultipartFile file) throws IOException {List users = ExcelFactory.createReader(file.getInputStream(), TeacherEval.class).read();teacherEvalService.saveTeacherEval(users);return Result.ok("导入成功");}

以上就是使用tool-excel操作excel的方法,接下来我么看看其他注解使用;

4、数据校验的使用:

在导出模板时,我们可以对用户填写的内容进行数据格式校验,如下:

/*** 对数据的前十行进行校验,必须输入大于3的数字*/@ExcelField("用户名")@NumericValid(validationType = ValidType.TEXT_LENGTH, expr1 = "3", operatorType = OperatorType.GREATER_OR_EQUAL,boxLastRow = 10)private String userName;@ExcelField(value = "创建时间",pattern = "yyyy-MM-dd")/*** 时间只能输入在2019-10-11至2019-10-30范围的时间*/@DateValid(expr1 = "2019-10-12",expr2 = "2019-10-30")private Date createTime;

好了,以上就是使用工具导出Excel数据信息,今天就给大家介绍到这里吧,大家有什么不懂

的可以私信我~~❤️❤️

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/312317.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java gt_JAVA泛型知识--gt; lt;? extends Tgt;和lt;? super Tgt;

extends T> 和 super T> 是Java泛型中的“通配符(Wildcards)” 和 “边界(Bounds)”的概念extends T> 是指 “上界通配符(Upper Bounds Wildcards)”super T> 是指 “下界通配符(Lower Bounds Wildcards)”1. 为什么要用通配符和边界&#xff1f;使用泛型的过程…

使用SignalR从服务端主动推送警报日志到各种终端(桌面、移动、网页)

工作上有个业务&#xff0c;.Net Core WebAPI作为服务端&#xff0c;需要将运行过程中产生的日志分类&#xff0c;并实时推送到各种终端进行报警&#xff0c;终端有桌面(WPF)、移动(Xamarin.Forms)、网站(Angular.JS)等&#xff0c;使用SignalR进行警报日志推送。微信公众号&am…

java图形包_java流布局图形包

第一步&#xff1a;导包import java.awt.FlowLayout;import javax.swing.JButton;import javax.swing.JFrame;第二步&#xff1a;定义类public class TestFlayOut {public static void main(String[] args) {JFrame jf new JFrame("流布局DEMO"); //建立一个窗口Flo…

ASP.Net Core 3.1 中使用JWT认证

JWT认证简单介绍关于Jwt的介绍网上很多&#xff0c;此处不在赘述&#xff0c;我们主要看看jwt的结构。JWT主要由三部分组成&#xff0c;如下&#xff1a;HEADER.PAYLOAD.SIGNATUREHEADER包含token的元数据&#xff0c;主要是加密算法&#xff0c;和签名的类型&#xff0c;如下面…

C++继承的继承方式

继承方式一共有三种&#xff1a; 1.公共继承 2.保护继承 3.私有继承

与其每天重复,不如试着构建「正反馈闭环」

大家好&#xff0c;我是Z哥。我们程序员应该算是相对比较有毅力的一个群体了&#xff0c;毕竟入行的高门槛首先就刷掉了一批无法坚持到胜任coding工作的人。况且&#xff0c;新技术的更迭相比其它行业快的多&#xff0c;需要持续学习。即使这样&#xff0c;肯定每个程序员都还有…

2008至今,Chrome如何成长为霸主

2008 年&#xff0c;微软的 Internet Explorer&#xff08;IE&#xff09;浏览器几乎占据了全球浏览器市场份额的 60%&#xff1b;Mozilla 的 Firefox 紧随其后&#xff0c;市场份额约为三分之一&#xff1b;于当年 9 月 2 日初亮相的 Chrome 浏览器则仅占有 0.3% 的市场份额。…

C++继承中构造和析构顺序

子类继承父类后&#xff0c;当创建子类对象&#xff0c;也会调用父类的构造函数 问题&#xff1a;父类和子类的构造和析构顺序是谁先谁后&#xff1f; 代码如下&#xff1a; #include <iostream> using namespace std; //继承中的构造和析构顺序class Base {public:Ba…

linux java -xms_java.lang.OutOfMemoryError及解决方法

主要有3种比较常见的OutOfMemory Error&#xff1a;Java.lang.OutOfMemoryError: Java heap spacejava.lang.OutOfMemoryError: PermGen spacejava.lang.OutOfMemoryError: GC overhead limit exceeded1. java.lang.OutOfMemoryError: Java heap spaceJava heap space&#xff…

Excel模板导出之导出教材订购表

说明本教程主要说明如果使用Magicodes.IE.Excel完成教材订购表的Excel模板导出。要点本教程使用Magicodes.IE.Excel来完成Excel模板导出需要通过创建Dto来完成导出需要按要求准备Excel模板主要步骤1.安装包Magicodes.IE.Excel在本篇教程中&#xff0c;我们仅演示使用Excel来完成…

BeetleX网关非法Url请求拦截插件

一旦网站部署到互联网上&#xff0c;就会受到一些非法的请求&#xff0c;而这些请求的Url都是一些特定的路径或带上一些无关请求的字符用于探测一些服务存在的问题&#xff1b;还有这些请求会落到日志中&#xff0c;导致日志臃肿和转发到后台服务带来处理上的损耗。为了应对拦截…

java安装版本哪种好_我怎么知道我安装了哪个版本的Java?

问题描述我想开始玩java(最终到了可以为android或web编写基本小程序的地步)&#xff0c;但是我已经在我的计算机上(从过去的实验中)弄糟了java。我不确定我拥有哪个版本的Java&#xff0c;并且想知道是否有命令查看已安装且处于活动状态的Java版本。另外&#xff0c;哪个版本效…

UnitTest in .NET 系列文章目录

Photo &#xff1a;.NET单元测试的艺术文 | Edison Zhou这几天陆陆续续更新了UnitTest in .NET这个系列的文章&#xff0c;现将其总结成一个小目录。此外&#xff0c;特别推荐阅读Roy Osherove的《单元测试的艺术》一书&#xff0c;此文也是该书的精华内容的学习笔记总结。文章…

java蝇量模式_Head First设计模式——蝇量和解释器模式

蝇量蝇量模式&#xff1a;如果让某个类的一个实例能用来提供许多“虚拟实例”&#xff0c;就使用蝇量模式。在一个设计房子的平台中&#xff0c;周围要加上一些树&#xff0c;树有一个坐标XY坐标位置&#xff0c;而且可以根据树的年龄动态将自己绘制出来。如果我们创建许多树之…

如何运用领域驱动设计 - 聚合

概述DDD实战与进阶 - 值对象如何运用DDD - 实体如何运用领域驱动设计 - 领域服务在前几篇的博文中&#xff0c;我们已经学习到了如何运用实体和值对象。随着我们所在领域的不断深入&#xff0c;领域模型变得逐渐清晰&#xff0c;我们已经建立了足够丰富的实体和值对象。但随着实…

C++菱形继承

菱形继承概念&#xff1a; 1.两个派生类继承同一个基类 2.又有某个类同时继承着两个派生类 这种继承被称为菱形继承&#xff0c;或者钻石继承 举个例子&#xff1a; 菱形继承问题&#xff1a; 1.羊继承了动物的数据&#xff0c;鸵同样继承了动物的数据&#xff0c;当羊驼使…

EntityFramework Core动态加载模型,我们要知道些什么呢?

这篇文章源于一位问我的童鞋&#xff1a;在EntityFramework Core中如何动态加载模型呢&#xff1f;在学习EntityFramwork时关于这个问题已有对应童鞋给出答案&#xff0c;故没有过多研究&#xff0c;虽然最后解决了这位童鞋提出的问题&#xff0c;但是当我再次深入研究时&#…

C++多态的基本语法与原理剖析

多态分为两类 1.静态多态&#xff1a;函数重载和运算符重载属于静态多态&#xff0c;复用函数名 2.动态多态&#xff1a;派生类和虚函数实现运行时多态 静态多态和动态多态区别&#xff1a; 1.静态多态的函数地址早绑定&#xff0c;编译阶段确定函数地址 2.多态多态的函数地址…

从零开始开发 VS Code 插件之 Translator Helper

本文目录Translator Helper 介绍开发概述创建第一个VS Code Extension需求分析操作文本调用Google Translation API实现核心功能配置命令插件配置测试插件打包插件发布插件CI/CDIcon及README小结Translator Helper 介绍 微软 Docs 网站上线之后&#xff0c;我发现很多中文内容是…

【实战 Ids4】║ 又一个项目迁移完成(MVC)

迎周一&#xff0c;腊月十九&#xff0c;小年倒计时新年还有两周时间就要到了&#xff0c;学习可不能停&#xff0c;这几天一直在加班调休&#xff0c;周末也如此&#xff0c;不过也是趁着半夜凌晨的时间&#xff0c;继续迁移我的项目到IdentityServer4统一认证授权中心Blog.Id…