关注程序员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数据信息,今天就给大家介绍到这里吧,大家有什么不懂

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

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

  1. Java后端:10w行级别数据的Excel导入优化记录

    一些细节 数据导入:导入使用的模板由系统提供,格式是 xlsx (支持 65535+行数据) ,用户按照表头在对应列写入相应的数据 数据校验:数据校验有两种: 字段长度.字段正则表达式校验等,内存内校 ...

  2. java通过jxl处理execl空行_jxl操作Excel导入数据库之空行的处理

    jxl因其快速小巧受到大家的欢迎,但是jxl还是有许多不尽如人意的地方. 本文旨在解决jxl读取excel数据时无法自动取掉空行的问题,其实就是添加一个方法. ? //返回去掉空行的记录数 priva ...

  3. 百度编辑器导入word插件,支持带图片文档导入

    Laravel.thinkPHP框架需要先安装PHPword,需要用PHPword扩展将word转化成html.该插件主要由两部分组成:编辑器上传word插件和文档转换功能代码,最重要的是文档转换代码 ...

  4. js导出变量 vue_vue.js前端实现excel表格导出和获取headers里的信息

    前段时间写过一篇文章基于element实现后台管理系统,并提到excel表格导出功能,可能描述不是很详细,现在单独整理列出. 后端提供的接口: // 下载分拣列表 export function ge ...

  5. php中如何导出表格,PHP如何实现表格Excel的导出

    PHP如何实现表格Excel的导出 首先下载PHPExcel包并将包引入到项目中:然后实例化PHPExcel对象:接着设置表格的列,以及列队属性:再将数据添加到表格中:最后将表格文件数据输出即可. P ...

  6. 将Excel表格导入mysql数据表_如何把Excel导入mysql数据表的方法详解

    把Excel导入mysql数据表其实是一件非常的简单的事情了,我们可以通过多种方法来实现了,下面我们来看一些关于小编整理的把Excel导入mysql数据表的方法了. 方法一 把Excel导入mysql ...

  7. java jxls 科学计数_java通过jxls框架实现导入导出excel

    02 03 //读取 04 05 public class ReadExcel { 06 private final static String xmlConfig="student.xml ...

  8. java代码借助插件生成组织架构图并实现导出功能

    先说一下需求,前几天产品提出了一个很(恶)好(心)的需求,将组织机构生成架构图并且能导出,数据如下: 下面是架构图 根据数据和架构图可以看出来,其实就是有父子关系的数据而已,因为是Java项目且使用的 ...

  9. java 调用word插件_java一键生成word操作,比poi简单

    [Java] 纯文本查看 复制代码package com.jeeplus.modules.fact.util; import java.io.BufferedInputStream; import j ...

最新文章

  1. python中异常的姓名
  2. Vue keep-alive实践总结
  3. Java面向对象之静态属性静态方法、访问权限、getter与setter
  4. 日志分析(shell脚本)
  5. JNA (Java 本地访问)理论概述与入门
  6. html+placeholder+兼容问题,placeholder属性做兼容性处理
  7. 循环训练_特殊时期别出门,一套居家循环训练简单有趣又有效
  8. 史上最详细教你制作“U盘启动盘”重装Windows10系统
  9. pycharm报错The directory *** is registered as a Git root与 Can't start Git: git.exe
  10. JS 获取输入时间的前一年、前三个月
  11. 强力推荐mac快速查看应用快捷键工具:键指如飞FlyKey
  12. 美通企业日报 | 微软和宝马推出开放式制造平台;爱彼迎Plus在中国发展势头强劲...
  13. 基于esp32-cam毕设设计兼日志(1)
  14. c语言中f1等于f2详细意思,请c语言高手给我讲解一下这个题
  15. 专业术语:UV、PV
  16. 数据科学与计算机学院英文翻译,计算机系毕业论文中英文翻译英文
  17. 练习-Java类和对象之类的声明之复数运算
  18. MOOC浙江大学陈月、何钦铭老师《数据结构》学习笔记01
  19. 发那科机器人圆弧指令怎么用_FANUC机器人操作指南
  20. 使用HBase Coprocessor

热门文章

  1. 【iVX 初级工程师培训教程 10篇文拿证】04 画布及我和 iVX 合照
  2. 一秒点击屏幕次数测试_安卓App性能专项测试流畅度深度解析
  3. 她13岁自己造飞机,17岁进麻省理工,3篇黑洞论文被霍金引用......
  4. 这五部关于海洋的纪录片,每一帧都犹如壁纸!
  5. 活久见!一美国大爷发明了永不掉链子的自行车,垂直踩踏即可驱动
  6. 学会了!如果认错人了,就像这样亲一口!
  7. 做题不如巧做题,初中数学题型解题技巧都在这!
  8. 灯泡里的钨丝是怎么放进去的,这个视频解开我20多年的疑惑!
  9. 使用aconda3-5.1.0(Python3.6.4) 搭建pyspark远程部署
  10. 建立学生选课表 mysql 语句_MySQL常用SQL语句(Python实现学生、课程、选课表增删改查)...