IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> spring boot项目实现excel的导入导出 -> 正文阅读

[Java知识库]spring boot项目实现excel的导入导出


本文采用的是EasyPOI操作Excel

一、添加依赖

<dependency>
	<groupId>cn.afterturn</groupId>
	<artifactId>easypoi-spring-boot-starter</artifactId>
	<version>3.3.0</version>
</dependency>

二、导出excel

1、编写实体类,添加注解
/**
 * @description 学生档案记录实体
 * @author zzy
 * @date 2021年07月18日 15:36
 */
@Data
public class StudentRecord {
    private Long id;
    @Excel(name = "姓名")
    private String name;
    @Excel(name = "性别",replace = {"男_0","女_1"})
    private Integer sex;
    @Excel(name = "学校")
    private String college;
    @Excel(name = "年级")
    private String grade;
    @Excel(name = "班级")
    private String className;
    @Excel(name = "手机号")
    private Long phoneNumber;
    @Excel(name = "创建时间",format = "yyyy-mm-dd hh:mm:ss")
    private String createTime;
    private String image;
}

注意:添加了@Excel注解的会被导出或导入;replace = {“男_0”,“女_1”}在导出时会把0替换成男,1替换成女,导入则相反;format = "yyyy-mm-dd hh:mm:ss"导出时对时间进行格式化。具体的注解属性请看文章末尾

2、编写Controller
@RequestMapping("exportStudentRecord")
    public void exportStudentRecord(HttpServletResponse response) {
    	// 查询学生信息,这是从数据库中查出来的学生信息
        List<StudentRecord> recordList = studentRecordService.list();
        try {
            // 设置响应输出的头类型及下载文件的默认名称
            String fileName = new String("demo信息表.xls".getBytes("utf-8"), "ISO-8859-1");
            response.addHeader("Content-Disposition", "attachment;filename=" + fileName);
            response.setContentType("application/vnd.ms-excel;charset=gb2312");

            //导出
            Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), StudentRecord.class, recordList);
            workbook.write(response.getOutputStream());
            log.info("请求 exportExcel end ......");
        } catch (IOException e) {
            log.info("请求 exportExcel 异常:{}", e.getMessage());
        }

    }

浏览器请求http://localhost:8080/demo/exportStudentRecord会自动下载excel,打开如下

在这里插入图片描述

三、导入excel

编写Controller
@RequestMapping("importStudentRecord")
    public void importStudentRecord() {

        try{
        	// 将导入的数据赋值给学生信息的recordList集合,test.xls是桌面上的一个excel表
            List<StudentRecord> recordList = ExcelImportUtil.importExcel(new File("C:\\Users\\zzy\\Desktop\\test.xls"),StudentRecord.class,new ImportParams());
            // 打印导入的recordList
            log.info("importStudentRecord:{}", recordList);
            // 调用mybatis plus的批量插入方法,插入到数据库
            studentRecordService.saveBatch(recordList);
        } catch (Exception e){
            log.info(" Excel 导入异常:{}", e.getMessage());
        }
    }

excel文件
在这里插入图片描述

日志打印结果

importStudentRecord:
	[
		StudentRecord(id=null, name=张三, sex=0, college=清华大学, grade=2017, className=一班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=李四, sex=1, college=北京大学, grade=2017, className=一班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=王五, sex=1, college=北京大学, grade=2017, className=一班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=王柳, sex=0, college=北京大学, grade=2017, className=一班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=1, sex=0, college=北京大学, grade=2017, className=二班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=2, sex=1, college=清华大学, grade=2017, className=二班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=3, sex=0, college=清华大学, grade=2017, className=二班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null), 
		StudentRecord(id=null, name=4, sex=0, college=清华大学, grade=2017, className=二班, phoneNumber=15230641011, createTime=2020-06-06 10:06:15, image=null)
	]

四、@Excel注解的属性

属性类型说明
nameStringnull列名
needMergebooleanfasle纵向合并单元格
orderNumString“0”列的排序,支持name_id
replaceString[]{}值的替换 导出是{a_id,b_id} 导入反过来
savePathString“upload”导入文件保存路径
typeint1导出类型 1 是文本 2 是图片,3 是函数,10 是数字 默认是文本
widthdouble10列宽
heightdouble10列高,后期打算统一使用@ExcelTarget的height,这个会被废弃,注意
isStatisticsbooleanfasle自动统计数据,在追加一行统计,把所有数据都和输出这个处理会吞没异常,请注意这一点
isHyperlinkbooleanfasle超链接,如果是需要实现接口返回对象
isImportFieldbooleantrue校验字段,看看这个字段是不是导入的Excel中有,如果没有说明是错误的Excel,读取失败,支持name_id
exportFormatString“”导出的时间格式,以这个是否为空来判断是否需要格式化日期
importFormatString“”导入的时间格式,以这个是否为空来判断是否需要格式化日期
formatString“”时间格式,相当于同时设置了exportFormat 和 importFormat
databaseFormatString“yyyyMMddHHmmss”导出时间设置,如果字段是Date类型则不需要设置 数据库如果是string 类型,这个需要设置这个数据库格式,用以转换时间格式输出
numFormatString“”数字格式化,参数是Pattern,使用的对象是DecimalFormat
imageTypeint1导出类型 1 从file读取 2 是从数据库中读取 默认是文件 同样导入也是一样的
suffixString“”文字后缀,如% 90 变成90%
isWrapbooleantrue是否换行 即支持\n
mergeRelyint[]{}合并单元格依赖关系,比如第二列合并是基于第一列 则{1}就可以了
mergeVerticalbooleanfasle纵向合并内容相同的单元格
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-09 13:40:59  更:2021-08-09 13:41:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/10 19:30:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码