springboot-poi ---封装注解式导入导出
此demo 是基于poi封装对象式注解导入导出,项目框架为springboot项目!
简单的说明一下此demo涉及到的知识点,希望能给初学者带来方便!
- poi-excel 基本操作(工具)
- 自定义注解的使用
- 全局异常捕获的定义
- jkd1.8新特性:Lambda 表达式 、函数式接口 等等
- 统一出参包装类
- lombok ...
- 比较适合初学者~
这份excel是无法定义复杂的excel模版的,只能适用于最简单的excel导入导出,若不符合需求,请自行更改~
大致说一下提供的excel工具吧!
导出:
/**
* 导出模版
*
* @param excelName excel 名称
* @param clazz 数据集
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportTemplate(String excelName, Class<T> clazz, HttpServletResponse response)
/**
* 导出模版
*
* @param excelName excel 名称
* @param clazz 数据集
* @param type excel 类型
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportTemplate(String excelName, Class<T> clazz, Type type, HttpServletResponse response)
/**
* excel 导出 (对象)
*
* @param excelName excel 名称
* @param list 数据集
* @param clazz 反射clazz
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportExcel(String excelName, List<T> list, Class<T> clazz, HttpServletResponse response)
/**
* excel 导出 (对象)
*
* @param excelName excel 名称
* @param list 数据集
* @param clazz 反射clazz
* @param type excel 类型
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportExcel(String excelName, List<T> list, Class<T> clazz, Type type, HttpServletResponse response)
/**
* excel 导出 (Map)
*
* @param excelName excel 名称
* @param clazz 反射clazz
* @param list 数据集
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportExcel(String excelName, Class<T> clazz, List<Map<String, Object>> list, HttpServletResponse response)
/**
* excel 导出 (Map)
*
* @param excelName excel 名称
* @param clazz
* @param list 数据集
* @param type excel 类型
* @param response 使用response可以导出到浏览器
* @param <T>
* @return
*/
public static <T> Boolean exportExcel(String excelName, Class<T> clazz, List<Map<String, Object>> list, Type type, HttpServletResponse response)
导入:
/**
* 传入文本对象输出list集合(导入)
*
* @param file 流文件
* @param clazz 要转义成的类对象
* @return
*/
public static <T> List<T> importExcel(MultipartFile file, Class<T> clazz)
excel注解类,提供了几个简单的判断处理:
/**
* <p>
* excel 注解
* </p>
*
* @author <a href="mailto:yangyanrui@yidianlife.com">xiaoyang</a>
* @version V0.0.1
* @date 2019年09月10日
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface Excel {
/**
* 表头中文
*
* @return
*/
String titleName();
/**
* 列宽
*
* @return
*/
int titleSize() default 30;
/**
* 字段顺序 正序
*
* @return
*/
int orderNum();
/**
* 是否允许空值 ,默认不允许
* <p>
* false:不允许 true :允许
*
* @return
*/
boolean empty() default false;
/**
* 内部类
*
* @return
*/
CellType type() default @CellType;
/**
* 设置格式
* 默认:
* 时间:yyyy-MM-dd HH:mm:ss
* 小数点:两位,四舍五入
*
* @return
*/
@interface CellType {
TimeType timeType() default TimeType.TIMEF_FORMAT;
DecimalType decimalType() default DecimalType.two;
}
}
TimeType 工具类:
/**
* <p>
* 日期格式
* </p>
*
* @author <a href="mailto:yangyanrui@yidianlife.com">xiaoyang</a>
* @version V0.0.1
* @date 2019年09月20日
*/
public enum TimeType {
/**
* yyyy-MM-dd
*/
DATE_FORMAT("yyyy-MM-dd"),
/**
* yyyy-MM
*/
YEAR_S_MONTH("yyyy-MM"),
/**
* yyyyMM
*/
YEAR_MONTH("yyyyMM"),
/**
* yyyy-MM-dd HH:mm:ss
*/
TIMEF_FORMAT("yyyy-MM-dd HH:mm:ss"),
/**
* yyyy-MM-dd HH:mm:ss.SSS
*/
MSEL_FORMAT("yyyy-MM-dd HH:mm:ss.SSS"),
/**
* yyyy年MM月dd日
*/
ZHCN_DATE_FORMAT("yyyy年MM月dd日"),
/**
* yyyy年MM月dd日HH时mm分ss秒
*/
ZHCN_TIME_FORMAT("yyyy年MM月dd日HH时mm分ss秒"),
/**
* yyyy年MM月dd日HH时mm分ss秒SSS毫秒
*/
ZHCN_MSEL_FORMAT("yyyy年MM月dd日HH时mm分ss秒SSS毫秒"),
/**
* yyyyMMdd
*/
DATE_STR_FORMAT("yyyyMMdd"),
/**
* yyyyMMddHHmmss
*/
TIME_STR_FORMAT("yyyyMMddHHmmss"),
/**
* yyyyMMddHHmmssSSS
*/
MSEL_STR_FORMAT("yyyyMMddHHmmssSSS"),
/**
* yyyy-MM-dd HH:mm
*/
MSEL_MIU_FORMAT("yyyy-MM-dd HH:mm"),
/**
* yyyyMMddHH
*/
MS_MIU_FORMAT("yyyyMMddHH");
/**
* 日期格式
*/
private String timeType;
/**
* 日期格式
*
* @param timeType
*/
TimeType(String timeType) {
this.timeType = timeType;
}
/**
* 获取日期格式
*
* @return
*/
public String getTimeType() {
return timeType;
}
}
DecimalType 工具类:
/**
* <p>
* 小数点格式
* </p>
*
* @author <a href="mailto:yangyanrui@yidianlife.com">xiaoyang</a>
* @version V0.0.1
* @date 2019年09月20日
*/
public enum DecimalType {
/**
* 一位
*/
one(1, "0.0"),
/**
* 两位
*/
two(2, "0.00"),
/**
* 三位
*/
three(3, "0.000"),
/**
* 四位
*/
four(4, "0.0000"),
/**
* 五位
*/
five(5, "0.00000");
/**
* 日期格式
*/
private String decimal;
private int scale;
/**
* 日期格式
*
* @param scale
* @param decimal
*/
DecimalType(int scale, String decimal) {
this.scale = scale;
this.decimal = decimal;
}
/**
* 获取日期格式
*
* @return
*/
public String getDecimal() {
return decimal;
}
/**
* 获取日期格式
*
* @return
*/
public int getScale() {
return scale;
}
}
附上GitHub地址:https://github.com/yangqiyue/excel
springboot-poi ---封装注解式导入导出的更多相关文章
- poi实现excel的导入导出功能
Java使用poi实现excel的导入导出功能: 工具类ExcelUtil,用于解析和初始化excel的数据:代码如下 package com.raycloud.kmmp.item.service.u ...
- SpringBoot 实现 excel 全自由导入导出,性能强的离谱,用起来还特优雅
一.简介 在实际的业务系统开发过程中,操作 Excel 实现数据的导入导出基本上是个非常常见的需求. 之前,我们有介绍一款非常好用的工具:EasyPoi,有读者提出在数据量大的情况下,EasyPoi ...
- 一个基于POI的通用excel导入导出工具类的简单实现及使用方法
前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...
- SSM中使用POI实现excel的导入导出
环境:导入POI对应的包 环境: Spring+SpringMVC+Mybatis POI对应的包 <dependency> <groupId>org.apache.poi&l ...
- Java集成POI进行Excele的导入导出,以及报错: java.lang.AbstractMethodError..........
报错信息如下 java.lang.AbstractMethodError: org.apache.poi.xssf.usermodel.XSSFCell.setCellType(Lorg/apache ...
- 用poi框架进行批量导入导出实例
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能.我们这里使用poi对数据库中的数据进行批量导出,以及 ...
- 使用Poi对EXCLE的导入导出
import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import ...
- springboot整合easyexcel实现Excel导入导出
easyexcel:快速.简单避免OOM的java处理Excel工具 Java解析.生成Excel比较有名的框架有Apache poi.jxl.但他们都存在一个严重的问题就是非常的耗内存,poi有一套 ...
- POI实现excel的导入导出
引入依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</arti ...
- poi管道流的导入导出
/** * 导入学生信息 * * @param classid * @param uploadFilePath * @return */ public boolean uploadStudentFil ...
随机推荐
- JavaScript基础学习之一
目录 let和var之间的区别 作用域不同 变量提升 暂时性死区(temporal dead zone,简称 TDZ) 相同作用域下的重复声明 脚本调用 数据类型 Boolean Object 对象 ...
- rust-must-know-crates-5ad8 100DayOfRust
https://dev.to/cad97/rust-must-know-crates-5ad8 https://dev.to/search?q=100DayOfRust https://fastert ...
- HTTP 认证授权技术归纳
原文:https://coolshell.cn/articles/19395.html
- 一、ptthon安装
1.在 Window 平台上安装 Python 的简单步骤,打开 WEB 浏览器访问:www.python.org,选择Downloads 2.然后在该页面选择需要下载的版本, 3.下载完成后直接双击 ...
- U-boot分析之编译体验
1. 如图可以看到的是PC和嵌入式系统的区别 PC第一步是上电,进入BIOS而嵌入式系统进入bootloader 接着进入操作系统而嵌入式式进入Linux内核 PC识别C盘,D盘,而嵌入式系统则挂载根 ...
- Visual Studio Tools for Apache Cordova 使用web技术构建使用Ios Andriod 和 windows 的应用
1.vs 开发web app 2.官方的解说
- 学习记录--C++多态性简答+编程题
#include<iostream> #include<string> //双目运算符:运算符作用域两个操作数 //定义一个复数类,重载"+",作为复数类的 ...
- 痞子衡嵌入式:分享一个i.MXRT系列配套DRAM压力测试上位机工具(i.MXRT DRAM Tester)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦SE团队制作的i.MXRT配套DRAM压力测试上位机工具. 事情源于痞子衡的技术交流群里的提问,有群友在恩智浦官方技术公众号 [恩 ...
- 【读书笔记】组合计数-Tilings-引言部分
Tilings-引言部分 目录 一些形式化定义 各种各样的Tilings例子 Example 9.1.1 Example 9.1.2 Example 9.1.3 Thurston and Lagari ...
- 003-Cruehead-CrackMeV3
第二个需要写注册机 首先查看文件,打开文件,什么也没有,help ->about,弹出下面的弹窗 看来是没有什么线索,直接放进OD里面 这里有一个函数CreatFileA,这个函数目的是访问一个 ...