在SpringBoot: SpringBoot里面创建导出Excel的接口教程

在Web项目中,难免需要导出Excel这样的功能,后端接口怎么实现呢,Controller代码在下面,复制到项目的Controller中即可使用:

首先加入Excel的依赖,本例中我们用apache的poi:

<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi</artifactId>
 <version>3.17</version>
</dependency>

后台导出Excel的Controller接口代码:

import org.apache.poi.hssf.usermodel.*;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Controller
public class ExcelController {

 /**
 * Excel表格导出接口
 * http://localhost:8080/ExcelDownload
 * @param response response对象
 * @throws IOException 抛IO异常
 */
 @RequestMapping("/ExcelDownload")
 public void excelDownload(HttpServletResponse response) throws IOException {
 //表头数据
 String[] header = {"ID", "姓名", "性别", "年龄", "地址", "分数"};

 //数据内容
 String[] student1 = {"1", "小红", "女", "23", "成都青羊区", "96"};
 String[] student2 = {"2", "小强", "男", "26", "成都金牛区", "91"};
 String[] student3 = {"3", "小明", "男", "28", "成都武侯区", "90"};

 //声明一个工作簿
 HSSFWorkbook workbook = new HSSFWorkbook();

 //生成一个表格,设置表格名称为"学生表"
 HSSFSheet sheet = workbook.createSheet("学生表");

 //设置表格列宽度为10个字节
 sheet.setDefaultColumnWidth(10);

 //创建第一行表头
 HSSFRow headrow = sheet.createRow(0);

 //遍历添加表头(下面模拟遍历学生,也是同样的操作过程)
 for (int i = 0; i < header.length; i++) {
  //创建一个单元格
  HSSFCell cell = headrow.createCell(i);

  //创建一个内容对象
  HSSFRichTextString text = new HSSFRichTextString(header[i]);

  //将内容对象的文字内容写入到单元格中
  cell.setCellValue(text);
 }

 //模拟遍历结果集,把内容加入表格
 //模拟遍历第一个学生
 HSSFRow row1 = sheet.createRow(1);
 for (int i = 0; i < student1.length; i++) {
  HSSFCell cell = row1.createCell(i);
  HSSFRichTextString text = new HSSFRichTextString(student1[i]);
  cell.setCellValue(text);
 }

 //模拟遍历第二个学生
 HSSFRow row2 = sheet.createRow(2);
 for (int i = 0; i < student2.length; i++) {
  HSSFCell cell = row2.createCell(i);
  HSSFRichTextString text = new HSSFRichTextString(student2[i]);
  cell.setCellValue(text);
 }

 //模拟遍历第三个学生
 HSSFRow row3 = sheet.createRow(3);
 for (int i = 0; i < student3.length; i++) {
  HSSFCell cell = row3.createCell(i);
  HSSFRichTextString text = new HSSFRichTextString(student3[i]);
  cell.setCellValue(text);
 }

 //准备将Excel的输出流通过response输出到页面下载
 //八进制输出流
 response.setContentType("application/octet-stream");

 //这后面可以设置导出Excel的名称,此例中名为student.xls
 response.setHeader("Content-disposition", "attachment;filename=student.xls");

 //刷新缓冲
 response.flushBuffer();

 //workbook将Excel写入到response的输出流中,供页面下载
 workbook.write(response.getOutputStream());
 }
}

然后访问接口,弹出页面:

下载该Excel,打开后如下图:

至此为止,SpringBoot的后台Controller接口导出Excel数据表,已成功实现!

后来我封装了一个静态方法,可以在项目中作为工具类使用:

import org.apache.poi.hssf.usermodel.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;

/**
 * Excel工具类
 */
public class ExcelUtil {

 /**
 * Excel表格导出
 * @param response HttpServletResponse对象
 * @param excelData Excel表格的数据,封装为List<List<String>>
 * @param sheetName sheet的名字
 * @param fileName 导出Excel的文件名
 * @param columnWidth Excel表格的宽度,建议为15
 * @throws IOException 抛IO异常
 */
 public static void exportExcel(HttpServletResponse response,
     List<List<String>> excelData,
     String sheetName,
     String fileName,
     int columnWidth) throws IOException {

 //声明一个工作簿
 HSSFWorkbook workbook = new HSSFWorkbook();

 //生成一个表格,设置表格名称
 HSSFSheet sheet = workbook.createSheet(sheetName);

 //设置表格列宽度
 sheet.setDefaultColumnWidth(columnWidth);

 //写入List<List<String>>中的数据
 int rowIndex = 0;
 for(List<String> data : excelData){
  //创建一个row行,然后自增1
  HSSFRow row = sheet.createRow(rowIndex++);

  //遍历添加本行数据
  for (int i = 0; i < data.size(); i++) {
  //创建一个单元格
  HSSFCell cell = row.createCell(i);

  //创建一个内容对象
  HSSFRichTextString text = new HSSFRichTextString(data.get(i));

  //将内容对象的文字内容写入到单元格中
  cell.setCellValue(text);
  }
 }

 //准备将Excel的输出流通过response输出到页面下载
 //八进制输出流
 response.setContentType("application/octet-stream");

 //设置导出Excel的名称
 response.setHeader("Content-disposition", "attachment;filename=" + fileName);

 //刷新缓冲
 response.flushBuffer();

 //workbook将Excel写入到response的输出流中,供页面下载该Excel文件
 workbook.write(response.getOutputStream());

 //关闭workbook
 workbook.close();
 }
}

以上方法调用示例:

/**
 * Excel表格导出接口
 * http://localhost:8080/ExcelDownload
 * @param response response对象
 * @throws IOException 抛IO异常
 */
@RequestMapping("/ExcelDownload")
public void excelDownload(HttpServletResponse response) throws IOException {

 List<List<String>> excelData = new ArrayList<>();

 List<String> head = new ArrayList<>();
 head.add("第一列");
 head.add("第二列");
 head.add("第三列");

 List<String> data1 = new ArrayList<>();
 data1.add("123");
 data1.add("234");
 data1.add("345");

 List<String> data2 = new ArrayList<>();
 data2.add("abc");
 data2.add("bcd");
 data2.add("cde");

 excelData.add(head);
 excelData.add(data1);
 excelData.add(data2);

 String sheetName = "测试";
 String fileName = "ExcelTest.xls";

 ExcelUtil.exportExcel(response, excelData, sheetName, fileName, 15);
}

以上这篇在SpringBoot: SpringBoot里面创建导出Excel的接口教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java实现导出Excel的功能

    导出excel是咱Java开发的必备技能啦,之前项目有这个功能,现在将其独立出来,分享一下. 所用技术就是SpringBoot,然后是MVC架构模式. 废话不多说,直接上代码了,源码点末尾链接就可以下载. (1)新建一个SpringBoot项目(可以官网https://start.spring.io/直接生成下载,然后导入eclipse),项目结构如下: (2)修改pom文件,添加依赖: <dependency> <groupId>org.springframework.boot&

  • SpringBoot中EasyExcel实现Excel文件的导入导出

    前言 在我们日常的开发过程中经常会使用Excel文件的形式来批量地上传下载系统数据,我们最常用的工具是Apache poi,但是如果数据到底上百万时,将会造成内存溢出的问题,那么我们怎么去实现百万数据批量导入导出. 正文 Easyexcel Easyexcel 是阿里巴巴的开源项目,用来优化Excel文件处理过程: poi消耗内存严重:Java解析.生成Excel比较有名的框架有Apache poi.jxl.但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的

  • Springboot使用POI实现导出Excel文件示例

    前面讲述了使用POI导出Word文件和读取Excel文件,这两个例子都相对简单,接下来要讲述的使用POI导出Excel文件要复杂得多,内容也会比较长. 创建表头信息 表头信息用于自动生成表头结构及排序 public class ExcelHeader implements Comparable<ExcelHeader>{ /** * excel的标题名称 */ private String title; /** * 每一个标题的顺序 */ private int order; /** * 说对

  • 在SpringBoot: SpringBoot里面创建导出Excel的接口教程

    在Web项目中,难免需要导出Excel这样的功能,后端接口怎么实现呢,Controller代码在下面,复制到项目的Controller中即可使用: 首先加入Excel的依赖,本例中我们用apache的poi: <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.17</version> </dep

  • SpringBoot+Hutool+thymeleaf完成导出Excel的实现方法

    目录 1.引入依赖 2.创建实体类 3.创建导出接口 4.创建html 5.测试导出 导出Excel的框架有很多种,POI相对来说比较老了,很多Excel框架底层都是POI.有EasyPoi.EasyExcel.包括Hutool当中封装的也是POI.唯一不同的是Hutool工具包不局限与做Excel.他里面封装了大量的util,一般现在开发都会用到糊涂. 本篇示例当中不仅仅有后端,而且还提供了前端html,html当中利用js将后端 输出流直接下载为文件. 实现的效果如下:一点击导出文件直接下载

  • Springboot POI导出Excel(浏览器)

    本文实例为大家分享了Springboot POI导出Excel的具体代码,供大家参考,具体内容如下 需求:页面根据查询条件导出(浏览器) 由于本次导出数据量较大,这里采用XSSFWorkbook多线程进行导出,注:XSSFWorkbook导出excel文件结尾为:".xlsx". 导出不需要返回,如有返回则会报异常! //Controller @RequestMapping("/stateExport") public void stateExport(HttpSe

  • SpringBoot中使用JeecgBoot的Autopoi导出Excel的方法步骤

    说到导出 Excel,我们首先会想到 poi.jsxl 等,使用这些工具会显得笨重,学习难度大.今天学习使用 JeecgBoot 中的 Autopoi 导出 Excel,底层基于 easypoi,使用简单,还支持数据字典方式 一.开发前戏 1.引入 maven 依赖 <!-- AutoPoi Excel工具类--> <dependency> <groupId>org.jeecgframework</groupId> <artifactId>aut

  • SpringBoot+easypoi实现数据的Excel导出

    本文实例为大家分享了SpringBoot+easypoi实现数据的Excel导出的具体代码,供大家参考,具体内容如下 maven <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-spring-boot-starter</artifactId> <version>4.1.0</version> </dependency> Contr

  • elementUI+Springboot实现导出excel功能的全过程

    目录 前言 步骤 依赖包 element表格table 引入包 编写方法 完整实例 最终导出结果 结语 前言 在前面,我们其实已经完成了elementUI+springboot的导入功能springboot实现上传并解析Excel过程解析那么,现在也对这个导出功能进行一个汇总整理写出来其实,导出功能相对导入功能还是比较简单,本次不需要考虑到后端 步骤 依赖包 首先,我们需要引入vue的依赖包我用的是这个 npm install xlsx@^0.16.0 npm install file-save

  • Springboot实现导入导出Excel的方法

    目录 一.添加poi的maven依赖 二.自定义注解(Excel属性标题.位置等) 三.CustomExcelUtils编写 四.定义导出实体类 五.Controller层代码编写 一.添加poi的maven依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.13</version> </d

  • Springboot实现前后端分离excel下载

    目录 Springboot前后端分离excel下载 前后端分离Excle下载乱码问题 前端请求方式 : ajax请求 Springboot前后端分离excel下载 现在公司的技术栈是springboot作为后端,前端是vue, 现在要做excel的导出功能, 之前没做过,写一下记录下. springboot版本是2.0.6 poi 3.14 ,jdk1.8 类上面的注解是: @RestController /** * 导出excel * */ @GetMapping("export")

  • 使用VUE+SpringBoot+EasyExcel 整合导入导出数据的教程详解

    目录 1 前端 2 数据库 3 后端 3.1 contrller 3.2 mapper 3.3 bean 3.4 listener 3.5 config 3.6 配置文件 4 启动测试 创建一个普通的maven项目即可 项目目录结构 1 前端 存放在resources/static 下 index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo

随机推荐