EasyExcel入门介绍及工具类,网络下载excel

这篇具有很好参考价值的文章主要介绍了EasyExcel入门介绍及工具类,网络下载excel。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:在这里分享自己第一次使用EasyExcel并且编写工具类,且在接口中支持excel文件下载的一系列流程,包含所有前后端(JS+JAVA)完整代码,可以根据自己需要自行提取,仅供参考。

一.引入EasyExcel依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>2.2.7</version>
</dependency>

二.自定义创建一个实体类,如下,这里使用了lombok

package com.genew.nms.cloud.lm.vo;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.genew.nms.cloud.lm.config.LocalDateStringConverter;
import lombok.Data;
import lombok.experimental.Accessors;
import org.springframework.format.annotation.DateTimeFormat;

import java.io.Serializable;
import java.time.LocalDateTime;

/**
 * @author Salong
 * @date 2023/5/29 15:38
 */

@Data
@Accessors(chain = true)
public class UserModel implements Serializable {
    private static final long serialVersionUID = 1L;

    @ExcelIgnore
    private String id;

    @ExcelProperty(value = "User Name")
    @ColumnWidth(20)
    private String userId;

    @ExcelProperty(value = "User IP")
    @ColumnWidth(20)
    private String userIp;

    @ExcelProperty(value = "Log Time", converter = LocalDateStringConverter.class)
    @ColumnWidth(20)
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime logTime;


}

其中各个注解功能如下:

@ExceIgnore标注的属性,不会被EasyExcel读取识别;

@ExcelProperty(value = "用户名") 被此标记的对象属性,将会显示在‘用户名’的表头下面,此注解还有一个index字段,int类型,从1开始,可以不写,默认按照从上往下的顺序给excel排列。

@ColumnWidth(20) 表示此列的宽度,可以根据内容的长短自定义宽度

需要注意,日期类型的属性,在@ExcelProperty注解中需要额外添加coverter字段

三.编写EasyExcel工具类(这里有两个class,完整代码已贴出,直接复制即可使用)

1.ExcelUtils类
package com.genew.nms.cloud.lm.util;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.support.ExcelTypeEnum;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.fastjson2.JSON;
import lombok.extern.slf4j.Slf4j;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author Salong
 * @date 2022/8/18 10:51
 */

@Slf4j
public class ExcelUtils {

    /**
     * 本地访问
     * @param fileFullPath 本地完整路径
     * @param sheets  sheet模板
     */
    public static void writeLocalExcel(String fileFullPath, SheetModel... sheets) {
        if (null ==sheets || sheets.length==0){
            log.error("所需参数sheets缺失!");
        }
        ExcelWriter excelWriter = EasyExcel.write(fileFullPath).build();
        List<SheetModel> list = Arrays.asList(sheets);
        list.forEach(e->{
            WriteSheet writeSheet = EasyExcel.writerSheet(e.getIndex(), e.getSheetName()).head(e.getClazz()).build();
            excelWriter.write(e.getData(),writeSheet);
        });
        log.info("写入excel成功!");
        excelWriter.finish();
    }

    /**
     *
     * @param response http请求返回response对象
     * @param fileName excel文件名
     * @param excelTypeEnum excel后缀类型(输入ExcelTypeEnum.XLS或者ExcelTypeEnum.XLSX)
     * @param sheets  sheet表单模板
     * @throws IOException
     */
    public static void writeWebExcel(HttpServletResponse response, String fileName, ExcelTypeEnum excelTypeEnum, SheetModel... sheets) {
        if (null ==sheets || sheets.length==0){
            log.error("所需参数sheets缺失!");
        }
        List<SheetModel> list = Arrays.asList(sheets);
        try {
            OutputStream outputStream = getOutputStream(response, fileName,excelTypeEnum);
            ExcelWriter excelWriter = EasyExcel.write(outputStream).build();
            list.forEach(e->{
                WriteSheet writeSheet = EasyExcel.writerSheet(e.getIndex(), e.getSheetName()).head(e.getClazz()).build();
                excelWriter.write(e.getData(),writeSheet);
            });
            log.info("写入excel成功!");
            excelWriter.finish();
        } catch (IOException e) {
            log.error("excel导出出失败!", e);
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            Map<String, String> map = new HashMap<>();
            map.put("status", "500");
            map.put("message", "下载文件失败" + e.getMessage());
            try {
                response.getWriter().println(JSON.toJSONString(map));
            } catch (IOException ex) {
                log.error("response写入信息失败!",ex);
            }
        }
    }


    /**
     * 导出时生成OutputStream
     */
    private static OutputStream getOutputStream(HttpServletResponse response, String fileName,ExcelTypeEnum excelTypeEnum)throws IOException {
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        // 这里URLEncoder.encode可以防止中文乱码
        String file = URLEncoder.encode(fileName, "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + file + excelTypeEnum.getValue());
        return response.getOutputStream();
    }
}
2.SheetModel类
package com.genew.nms.cloud.lm.util;

import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serializable;
import java.util.List;

/**
 * @author Salong
 * @date 2022/8/18 10:52
 */

@Data
@Accessors(chain = true)
public class SheetModel<T> implements Serializable {
    /**
     * 表单排序(一个Excel的不同的sheet名称不能一样,会覆盖)
     */
    private int index;
    /**
     * sheet表单名称(一个Excel的不同的sheet名称不能一样,会覆盖)
     */
    private String sheetName;
    /**
     * 表单填充内容
     */
    private List<T> data;
    /**
     * 表头数据类型
     */
    private Class<T> clazz;
}

四.使用方法示例

其中下面演示的response为HttpServletResponse对象,可以用于在网络中传输,

本地生成的参考工具类ExcelUtils.writeLocalExcel方法,这里不一一举例。文章来源地址https://www.toymoban.com/news/detail-664389.html

//1.模拟获取到的数据信息,并且放在List中,这里用UserModel来举例
List<UserModel> users=new ArrayList<>();
//2.新建SheetModel对象(工作表)
SheetModel<UserModel> model = new SheetModel<>();
//3.构建SheetModel对象基本信息(工作表)
model.setData(users)
.setIndex(0)
.setSheetName("user log")
.setClazz(UserModel.class);

//其中,model为此excel中的一个工作表,若excel中有多个工作表,可重复构建多个model对象
//但是index不能一样,否则会覆盖内容
SheetModel<UserModel> model01 = new SheetModel<>();
model01 .setData(users)
.setIndex(1)
.setSheetName("user1 log")
.setClazz(UserModel.class);

//4.将上面定义的所有工作表写入到excel(上面的名称是工作表名称,这里的名称为excel名称)
ExcelUtils.writeWebExcel(response, "system Log", ExcelTypeEnum.XLS, model,model01);

五.前端接收文件(JS)

//js中定义,需要引入axios
export function cg(config){
      let url='/api/xxx';
      return axios.post(url,config,{responseType: 'blob'});
}

//vue中使用
cg(config).then((response)=>{
            const blob = new Blob([response.data], { type: "application/zip" });
            let url = window.URL.createObjectURL(blob);
            const link = document.createElement("a"); // 创建a标签
            link.href = url;
            link.download = "gc.zip"; // 重命名文件
            link.click();
            URL.revokeObjectURL(url); // 释放内存

          }).catch((err)=>{
            console.log(err);
          })   

到了这里,关于EasyExcel入门介绍及工具类,网络下载excel的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 为什么通过EasyExcel下载 Excel 文件时,response.setContentType(“application/octet-stream“) 这样设置,下载下来的文件不能显示文件名称?

    response.setContentType(\\\"application/octet-stream\\\") 是用来告诉浏览器服务器返回的数据是二进制流,因为 octet-stream 意味着 \\\"一个未知的字节流\\\"。当浏览器收到这个响应时,它无法确定数据类型,所以它的解析方式会尝试将这些未知字节自动转换为可读的格式。 当您使用 EasyExcel 将数据

    2024年02月13日
    浏览(36)
  • 【Alibaba工具型技术系列】「EasyExcel技术专题」实战技术针对于项目中常用的Excel操作指南

    EasyExcel教程 本文使用的技术是Alibaba集团开源的EasyExcel技术,该技术是针对Apache POI技术的封装和优化,主要解决了POI技术的耗内存问题,并且提供了较好的API使用。 使用步骤繁琐 动态写出Excel操作非常麻烦 对于新手来说,很难在短时间内上手 读写时需要占用较大的内容,当

    2024年01月19日
    浏览(33)
  • 网络安全|渗透测试入门学习,从零基础入门到精通—动态分析技术工具OllyDbg界面介绍

    目录 动态分析技术调试器 什么是OllyDbg OllyDbg能干什么 OllyDbg窗口介绍 1、反汇编面板窗口 2、信息面板窗口 3、数据面板窗口 4、寄存器面板窗口 5、栈面板窗口 动态分析技术中最重要的工具是调试器,分为用户模式和内核模式两种类型。用户模式调试器是指用来调试用户模式

    2024年02月11日
    浏览(38)
  • 2.1.1工具篇-Excel——Excel入门

    接下来几篇文章要跟大家分享工具篇中的第一个数据分析常用工具,也是最基础的工具——Excel。我将从数据分析的视角跟大家进行分享,本篇文章主要针对没用过Excel的同学,让其对Excel有个概念上的认识。 Excel是一款电子表格软件,通过在行和列上创建单元格形成的网格,

    2024年02月06日
    浏览(36)
  • EasyPoi快速入门(Excel导入导出工具)

    简介: easypoi是一款Excel快速导入导出的工具,最近有所使用,结合了网上的一些用法和官方文档的介绍,在在这里总结一下最简单的esaypoi导入Excel的实现,网上很多教程都已经封装了工具类,虽然方便,但第一次接触easypoi可能看的不是清晰,现在总结一下最为直观的SpringBoot集成easypoi快

    2023年04月22日
    浏览(36)
  • 开源Excel 处理工具库MyExcel介绍以及简单例子

            MyExcel是一个开源的Java库,用于简化Excel文件的处理。它提供了一种简单、高效的方式来读写Excel文件,支持多种格式,包括XLS、XLSX和CSV。MyExcel的设计目标是易于使用,同时提供足够的灵活性来处理复杂的Excel操作。         主要特点 - **简单易用**:MyExcel提供

    2024年02月22日
    浏览(34)
  • EasyExcel导出Excel文件

    方法一 导入EasyExcel依赖 创建实体类 OrderServiceImpl 如果希望多个sheet导出那么可以 测试类 方法二 导入EasyExcel依赖 编写ExcelUtil 编写Service层代码 controller层代码 方法一与方法二都使用了EasyExcel进行Excel的导出,区别在于方法一建立了实体类进行Excel的导出,这样的好处是可以直

    2024年02月14日
    浏览(29)
  • 基于EasyExcel的Excel读取

    1.引入依赖 2.读取器代码: 3.测试

    2024年02月12日
    浏览(36)
  • 使用EasyExcel读写Excel文件

    笔者之前一直使用POI读写Excel文件,最近有个需求需要读取大概80万行数据的Excel,使用POI读取到10.2万行左右就卡死不动了,而且CPU占用直接拉满到100%,内存占用也很高。 查找资料后,发现POI提供了读取大量数据的方法,但是用起来比较复杂。同时看到有人提到用EasyExcel读取

    2024年02月13日
    浏览(39)
  • EasyExcel读取EXcel文件内容

    目录 一 官方文档介绍 二 读取文件内容 1.根据文档内容建立读对象 2.创建读监听器 3.测试类代码 Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一

    2024年02月14日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包