百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel

yuyutoo 2025-05-08 07:46 5 浏览 0 评论

一、前言

小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。

常见的导出Excel的技术:

  • hutool
  • easyExcel
  • poi

hutool和easyExcel都是对poi的封装,使用起来更加方便!由于公司都是使用EasyExcel进行导出,小编也不能特立独行。如果想看poi和hutool导出的可以看一下小编的之前写的文章:
使用POI+hutool导入Excel并把内容添加到数据库中,直接可以用!!!_掉发的小王的博客-CSDN博客_poi导入excel到数据库

使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet.最详细!!!_掉发的小王的博客-CSDN博客_poi把数据导出到excel


话不多说,咱们直接开始。

二、导入Maven依赖

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

特别注意:
这里的版本应该适当高一些,不然我们在导出时有日期是jdk8新特性
LocalDateTime,会不支持的!
小编开始用的同事以前使用的2.几版本就出现不支持的问题,大家小心哈!!

三、编写导出实体类

@Data
@ColumnWidth(20)
public class Test implements Serializable {
    private static final long serialVersionUID = 337361630075002456L;

    @TableId(type= IdType.ASSIGN_ID)
    @ExcelProperty(value = "id",index = 0)
    private long id;

    @ExcelProperty(value = "名字",index = 1)
    private String name;

    @ExcelProperty(value = "性别",index = 2)
    private String gender;

    @ExcelProperty(value = "数据",index = 3)
    private String data;

    @ExcelProperty(value = "创建时间",index = 4)
    private LocalDateTime createDate;

    @ExcelProperty(value = "更新时间",index = 5)
    private LocalDateTime updateDate;

}

参数解读:
@ExcelProperty:加在需要导出的字段上,value是导出表头展示的内容,如果不写则会按照字段名字来当做表头。
经过小编测试:导出的实体类,不加这个注解也会导出,不过表头为字段名字!!

@ColumnWidth(20):设置每一个表头的长度,加载类上就是全部都是这个长度,加在字段上就是一个表头的长度!

如果你需要合并的话,需要自己指定策略,继承extends AbstractCellWriteHandler 重写afterCellDispose,就可以了;这里小编就不展示了,等后面有这个需求在给大家详细教学一下哈!!

四、测试

小编为了方便直接在controller里完成了,大家不要学哈,业务在service里写比较规范哈!

@RestController
@RequestMapping("/test")
@Slf4j
@RequiredArgsConstructor
public class TestController {

    private final TestService testService;

    @NonNull
    private TestMapper testMapper;

    @SneakyThrows
    @GetMapping("/easyExcel")
    public void easyExcel (HttpServletResponse response){
        String fileName = new String("导出excel.xlsx".getBytes(), StandardCharsets.ISO_8859_1);
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf8");
        response.setHeader("Content-disposition", "attachment;filename=" + fileName );
        List<Test> list = testMapper.selectList(null);
        ServletOutputStream outputStream = response.getOutputStream();
        EasyExcel.write(outputStream, Test.class)
                .sheet("sheet1")
                .doWrite(list);
    }
}

如果对@RequiredArgsConstructor不了解的可以看一下小编的这篇文章!

还在使用@Autowrired注入?不妨试试@RequiredArgsConstructor注解完美替代_掉发的小王的博客-CSDN博客

五、浏览器测试

我们现在浏览器里访问,地址:
http://localhost:8089/test/easyExcel

六、Postman测试

提醒:

通常情况下我们在企业级开发时,都是需要登录验证的,这时我们无法通过浏览器进行访问测试,这时我们需要使用Postman进行测试,开始小编导出的都是一推乱码,后来小伙伴告诉我,导出不能直接Send,要点击下面的Send And Download。现在给大家演示一下哈:

七、查看导出文件

我们可以看到没有乱码哈!

八、总结

我们这样就完成了测试,成功的导出了Excel。本篇只是简单的进行导出测试,可能你们的需求要美化,详细参考官网:EasyExcel · 语雀



有缘人才可以看得到的哦!!!

小王博客站

相关推荐

WMS系统设计拆解-入库管理1(wms入库作业流程图)

入库业务是仓储管理系统(WMS)中最基础、最关键的环节之一,直接影响到库存准确性、作业效率以及后续的出库和库内操作。作为仓储产品经理,深入理解入库业务的复杂性并设计出高效、灵活的解决方案,是提升仓储整...

WMS系统的序列号管理(smart cover序列号)

在现代物流和仓储管理中,序列号管理扮演着至关重要的角色。它不仅帮助企业追踪商品流转,还能有效防止盗窃和伪造。然而,许多企业在实施序列号管理时常常面临各种挑战。本文将详细介绍在WMS(仓库管理系统)中,...

什么是系统管理?#企业管理(系统管理主要包括哪些内容?)

什么是系统管理?邱奕玮,营利增长地图顾问。我们老说要搭建管理系统,搭建管理体系到底什么是管理系统?很多时候老板其实概念是很模管理,给员工说你要做流程,员工就做一套流程文件,然后又说要做绩效考,员工又做...

不愧是总经理,加班两周整理的“公司各系统管理流程汇编”太神了

...

公务员管理系统(公务员管理系统hzb怎么导出)

公务员管理系统headerfooter...

物流管理系统(比亚迪物流管理系统)

以管理员身份登录,进入系统业绩管理页面。1、创建界面后,继续完成相关操作。2、根据业绩管理模块的指引进行软件操作。3、更多模块请参见哲程CRM客户管理软件物流版官方操作手册。(9744083)...

更多驱动适配 + 跨平台共享,deepin深度操作系统打印管理升级

IT之家4月8日消息,深度操作系统今日发文宣布:为了解决打印机驱动的兼容性问题,deepin正式推出全新驱动下载平台,并升级了打印管理器,重点扩展驱动覆盖范围、优化跨平台兼容性、并深度支持...

ERP系统功能拆解——生产管理是什么?怎么用?

本文深入探讨了ERP系统中的生产管理功能,揭示了如何通过高效的计划和控制来优化生产过程。从生产工单的制定到生产入库,每一个环节都被详细拆解,展示了简道云ERP管理系统如何实现流程自动化和数据跟踪。这是...

如何在NetBeans IDE中写出更好的Javadoc

作为一名在IDR解决方案上的开发者,我花了我很多时间来增加Javadoc中JPedal的JavaPDF库,使之更易于使用。我认为这可能是非常有用的,显示你的NetBeansIDE中如何简化这个过程...

6个最佳的Netbeans扩展插件(netbeans gui)

作为一个IDR解决方案的开发者,我花费大量的时间了解NetBeans的PDF查看器和NetBeans插件。下面跟大家分享一下哪些插件是比较值得安装的。下面是我认为比较有趣并值得安装的6个NetBean...

HTTP404...前端必知,精辟简介(前端设置https)

1、介绍HTTP,超文本传输协议,是互联网中最为常用的一种网络协议。2、组成HTTP协议有HTTP请求和HTTP响应组成。...

会计人的 Python 速成指南:20 个常用代码块解析

--【AI会计革命:从账房先生到数据军师的跨界突围】【能力重构篇】泰山医院岳涛引言在数字化浪潮的冲击下,会计行业正经历着深刻变革。传统的账房先生式工作模式逐渐被智能化、自动化的流程所取代。对于会...

EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel

一、前言小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。...

用 Superb AI Suite 和 NVIDIA TAO Toolkit 创建高质量的计算机视觉应用

数据标记和模型训练一直被认为是团队在构建AI或机器学习基础设施时所面临的最大挑战。两者都是机器学习应用开发过程中的重要步骤,如果执行不当就会导致结果不准确和性能下降。...

二 计算机网络 前端学习 物理层 链路层 网络层 传输层 应用层 HTTP

一、基础概念请求和响应报文客户端发送一个请求报文给服务器,服务器根据请求报文中的信息进行处理,并将处理结果放入相应报文中返回给客户端。...

取消回复欢迎 发表评论: