EasyExcel文件导出简洁版

1. EasyExcel简介

EasyExcel是一个基于Java的简单、快速、lightweight的Excel处理库。它的主要特点包括:

  • 轻量级设计:
    EasyExcel的jar包大小仅约1MB,相比较其他Excel处理库如Apache POI来说更加轻量。
    采用内存友好的流式读写模式,无需一次性加载整个Excel文件到内存,大大减少了内存占用。
  • 高性能读写:
    通过事件驱动的读写模式,逐行处理数据,避免了对整个Excel文件的加载。
    在处理大Excel文件时,EasyExcel表现出优异的性能,远超传统的Excel操作库。
  • 使用简单:
    EasyExcel抽象了Excel操作的底层细节,提供了简单易用的API。
    开发者只需编写少量代码就可完成数据的读写操作,大幅提升了开发效率。
  • 丰富功能:
    除了基础的读写操作,EasyExcel还支持样式设置、公式计算、合并单元格等功能。
    同时还提供了Web导入导出的解决方案,简化了Web应用中的Excel交互。
  • 活跃社区:
    EasyExcel拥有良好的社区支持,有丰富的使用文档和示例代码。
    同时也有大量第三方插件和工具,为开发者提供全面的生态支持。

2. 依赖包引入

sh 复制代码
<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>easyexcel</artifactId>
   <version>4.0.2</version>
</dependency>

3. 核心代码

java 复制代码
public void exportExcel(String scriptId, HttpServletResponse response) {
        try {
            List<ScenesExportDto> scenesExportDtos = ***
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setCharacterEncoding("utf-8");
            // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
            String fileName = URLEncoder.encode("测试", "UTF-8").replaceAll("\\+", "%20");
            response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");

            EasyExcel.write(response.getOutputStream(), ScenesExportDto.class).sheet("场景").doWrite(scenesExportDtos);

        } catch (IOException e) {
            throw new RuntimeException(e);
        }
}
java 复制代码
@Data
// 设置头样式
@HeadStyle(fillPatternType = FillPatternTypeEnum.SOLID_FOREGROUND, fillForegroundColor = 55)
@ColumnWidth(25)
public class ScenesExportDto {
    // 设置列长
    @ColumnWidth(15)
    @ExcelProperty("场景序号")
    private Integer sort;

    // 设置该列内容粗体
    @ContentFontStyle(bold = BooleanEnum.TRUE)
    private String name;

    @ExcelProperty("时长(秒)")
    @ColumnWidth(10)
    private Integer duration;
}

更多示例,请查看官方文档

相关推荐
JH30733 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble4 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟4 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖4 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_12498707536 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_6 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.6 小时前
Day06——权限认证-项目集成
java
瑶山6 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy6 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法