Java中实现简单的Excel导出

 更新时间:2019年01月16日 10:26:06   作者:Haozz_1994  
今天小编就为大家分享一篇关于Java中实现简单的Excel导出,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

简单介绍一下Java中的Excel文件导出功能(基于HttpServletResponse实现下载)

首先,引入需要依赖的jar包:

<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi</artifactId>
 <version>3.14</version>
</dependency>
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi-ooxml</artifactId>
 <version>3.14</version>
</dependency>

编写一个工具类:

package exceloutput;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.UUID;
/**
 * @author haozz
 * @date 2018/6/6 9:57
 * @description excel导出抽象工具类
 **/
public abstract class ExportAbstractUtil {
  public void write(HttpServletResponse response, Workbook workbook){
    String fileName = UUID.randomUUID().toString()+".xls";
    pwrite(response,workbook,fileName);
  }
  public void write(HttpServletResponse response,Workbook workbook,String fileName){
    if(StringUtils.isEmpty(fileName)){
      fileName = UUID.randomUUID().toString()+".xls";
    }
    pwrite(response,workbook,fileName);
  }
  public void write(HttpServletResponse response, List<List<String>> lists,String fileName){
    if(StringUtils.isEmpty(fileName)){
      fileName = UUID.randomUUID().toString()+".xls";
    }
    SXSSFWorkbook workbook = new SXSSFWorkbook(lists.size());
    SXSSFSheet sheet = workbook.createSheet(fileName.substring(0,fileName.indexOf(".xls")));
    Integer rowIndex = 0;
    Row row = null;
    Cell cell = null;
    for(List<String> rowData: lists ){
      Integer columnIndex = 0;
      row = sheet.createRow(rowIndex++);
      for(String columnVal:rowData){
        cell = row.createCell(columnIndex++);
        cell.setCellValue(columnVal);
      }
    }
    pwrite(response,workbook,fileName);
  }
  private void pwrite(HttpServletResponse response,Workbook workbook,String fileName){
    response.setCharacterEncoding("UTF-8");
    response.setContentType("application/vnd.ms-excel;charset=UTF-8");
    try {
      response.addHeader("Content-Disposition", "attachment; filename="+new String(fileName.getBytes("UTF-8"),"ISO8859-1"));
    } catch (UnsupportedEncodingException e) {
      e.printStackTrace();
      fileName= UUID.randomUUID().toString()+".xls";
      response.addHeader("Content-Disposition", "attachment; filename="+fileName);
    }
    try {
      workbook.write(response.getOutputStream());
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

有了这个工具类就可以实现Excel导出了,代码不难,这里就不多解释了。

在SpringBoot项目中编写一个导出Excel的Controller,并继承上面的ExportAbstractUtil,给出一个接口用作测试:

package com.csdn.myboot.controller;
import com.csdn.myboot.utils.ExportAbstractUtil;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
 * @author haozz
 * @date 2018/6/6 10:14
 * @description
 **/
@Controller
@RequestMapping(value = "/index")
public class HelloCtrl extends ExportAbstractUtil{
  @RequestMapping(value = "/testExcelOutPut")
  @ResponseBody
  public void testExcelOutPut(HttpServletResponse response){
    //拼接数据start
    List<List<String>> lists = new ArrayList<List<String>>();
    String rows[] = {"year","month","day"};
    List<String> rowsTitle = Arrays.asList(rows);
    lists.add(rowsTitle);
    for(int i = 0; i<=9;i++){
      String [] rowss = {"1","2","3"};
      List<String> rowssList = Arrays.asList(rowss);
      lists.add(rowssList);
    }
    //拼接数据end
    write(response,lists,"导出Excel.xls");
  }
}

浏览器输入链接:

http://localhost:8099/index/testExcelOutPut

即可自动下载测试数据组成的Excel:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • spring根据controller中接收请求参数不同走不同service的实现方法

    spring根据controller中接收请求参数不同走不同service的实现方法

    这篇文章主要给大家介绍了关于spring实现根据controller中接收请求参数不同走不同service的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2018-11-11
  • Java Swing组件布局管理器之FlowLayout(流式布局)入门教程

    Java Swing组件布局管理器之FlowLayout(流式布局)入门教程

    这篇文章主要介绍了Java Swing组件布局管理器之FlowLayout(流式布局),结合实例形式分析了Swing组件布局管理器FlowLayout流式布局的常用方法及相关使用技巧,需要的朋友可以参考下
    2017-11-11
  • Java Calendar类使用之日期和时间处理指南

    Java Calendar类使用之日期和时间处理指南

    这篇文章主要给大家介绍了关于Java Calendar类使用之日期和时间处理指南的相关资料,Calendar类是Java中用于处理日期和时间的抽象类,它提供了一种独立于特定日历系统的方式来处理日期和时间,需要的朋友可以参考下
    2023-12-12
  • Java Web学习教程之Hibernate And MyBatis的理解

    Java Web学习教程之Hibernate And MyBatis的理解

    这篇文章主要给大家介绍了关于Java Web学习教程之Hibernate And MyBatis的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们来一起学习学习吧。
    2018-04-04
  • Log4j如何屏蔽某个类的日志打印

    Log4j如何屏蔽某个类的日志打印

    这篇文章主要介绍了Log4j如何屏蔽某个类的日志打印,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java获得元素属性的注解信息的步骤

    Java获得元素属性的注解信息的步骤

    在Java编程中,注解是一种为代码添加元数据的方式,通过反射机制,我们可以获取元素属性上的注解信息,这个过程对于框架开发和元数据处理非常有用,能够实现更灵活的功能,对java获得元素属性的注解信息相关知识感兴趣的朋友一起看看吧
    2024-09-09
  • application.yml和bootstrap.yml不生效的3种解决方案

    application.yml和bootstrap.yml不生效的3种解决方案

    SpringBoot默认支持 properties(.properties) 和 YAML(.yml .yaml ) 配置文件,本文主要介绍了application.yml和bootstrap.yml不生效的3种解决方案,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • Spring Web项目spring配置文件随服务器启动时自动加载

    Spring Web项目spring配置文件随服务器启动时自动加载

    这篇文章主要介绍了Spring Web项目spring配置文件随服务器启动时自动加载,加载spring的配置文件,并且只加载一次,从而提高程序效率。具体内容详情大家通过本文一起学习吧
    2018-01-01
  • Spring Get请求与post请求的实现

    Spring Get请求与post请求的实现

    在Spring中,GET请求和POST请求是两种常见的HTTP请求方法,用于与服务器进行交互,本文详细的介绍一下Spring Get请求与post请求的实现,感兴趣的可以了解一下
    2023-10-10
  • Java中关于Collections集合工具类的详细介绍

    Java中关于Collections集合工具类的详细介绍

    Java提供了一个操作Set、List和Map等集合的工具类:Collections,该工具提供了大量方法对集合元素进行排序、查询和修改等操作,还提供了将集合对象设置为不可变、对集合对象实现同步控制等方法
    2021-09-09

最新评论