(从0到1)EasyExcel+SpringBoot+SpringCloud实现数据导出

文章目录

概要

完成数据转换为excel表格的数据并且可以成功导出。

整体架构流程、

  1. 引入easyexcel注解
  2. 写数据模板
  3. 调整数据格式
  4. 编写Controller层代码完成使用

技术名词流程

引入easyexcel注解

java 复制代码
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.3</version>
        </dependency>

写数据模板(完成每一列的格式编写)

java 复制代码
package com.order.entity.dto;

import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentRowHeight;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import lombok.Builder;
import lombok.Data;

import java.util.Date;
@Data
@HeadRowHeight(value = 50)
@ContentRowHeight(value = 50)
//商品报表dto
public class OrderMsgDto {
    //商品Id
    @ColumnWidth(15)
    @ExcelProperty(value = "商品id")
    private Integer  productId;
    //商品名
    @ColumnWidth(20)
    @ExcelProperty(value = "商品名")
    private String productName;
    //商品品牌
    @ColumnWidth(20)
    @ExcelProperty(value = "商品品牌")
    private String brand;
    @ColumnWidth(20)
    @ExcelProperty(value = "订单量")
    //商品订单量
    private Integer orderCount;
    //商品收益
    @ColumnWidth(20)
    @ExcelProperty(value = "商品收益")
    private Integer orderIncome;
    @ExcelProperty(value = "数据更新日期")
    //数据更新日期
    private Date latestUpdateTime;
    @ColumnWidth(20)
    @ExcelProperty(value = "数据开始日期")
    //数据开始日期
    private Date earliestCreateTime;


}

调整数据格式(继承easyexcel的格式来完成格式管理)

java 复制代码
package com.order.util;
import com.alibaba.excel.write.handler.AbstractRowWriteHandler;

import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteTableHolder;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Cell;

/**
 * 自定义的 Excel 行写入处理器。
 * 用于在使用 EasyExcel 写入过程中自定义单元格的样式。
 */
public class CustomStyleHandler extends AbstractRowWriteHandler {


    @Override
    public void afterRowDispose(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, Integer relativeRowIndex, Boolean isHead)
    {
        // 获取当前工作表的工作簿对象,用以创建样式和字体
        Workbook workbook = writeSheetHolder.getSheet().getWorkbook();
        // 创建单元格样式对象
        CellStyle cellStyle = workbook.createCellStyle();
        // 设置单元格文本居中对齐
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        // 创建字体对象
        Font font = workbook.createFont();
        // 设置字体名称
        font.setFontName("Arial");
        // 设置字体大小
        font.setFontHeightInPoints((short) 12);
        // 将字体应用到样式中
        cellStyle.setFont(font);

        // 如果当前行是表头行
        if (isHead) {
            // 设置表头背景色为灰色
            cellStyle.setFillForegroundColor(IndexedColors.GREY_25_PERCENT.getIndex());
            // 设置填充模式为实心填充
            cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
            // 设置字体为粗体
            font.setBold(true);
            // 设置字体颜色为白色
            font.setColor(IndexedColors.WHITE.getIndex());
            // 重新将字体应用到样式中(因为字体属性已更改)
            cellStyle.setFont(font);
        }

        // 遍历行中的每一个单元格,将定义好的样式应用到这些单元格上
        for (Cell cell : row) {
            cell.setCellStyle(cellStyle);
        }
    }
}

编写Controller层代码完成使用

java 复制代码
    //数据导出(全部)
    @RequestMapping(value = "/downloadExcel")
    public void downloadExcel(HttpServletRequest request,
                              HttpServletResponse response) throws Exception {
        List<OrderMsgDto> list = jxOrderService.queryOrderByPIdList();
        List<OrderMsgDto> orderMsgDtoList = orderMsgUtil.prepareData(list);
        // 设置响应头
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        // 设置防止中文名乱码
        String filename = URLEncoder.encode("数据报表", "utf-8");
        // 文件下载方式(附件下载还是在当前浏览器打开)
        response.setHeader("Content-disposition", "attachment;filename=" +
                filename + ".xlsx");
        // 构建写入到excel文件的数据

        // 写入数据到excel
        EasyExcel.write(response.getOutputStream(), OrderMsgDto.class)
                .registerWriteHandler(new CustomStyleHandler())
                .sheet("用户信息")
                .doWrite(orderMsgDtoList);

    }
相关推荐
customer082 小时前
【开源免费】基于SpringBoot+Vue.JS体育馆管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
Miketutu3 小时前
Spring MVC消息转换器
java·spring
乔冠宇3 小时前
Java手写简单Merkle树
java·区块链·merkle树
LUCIAZZZ4 小时前
简单的SQL语句的快速复习
java·数据库·sql
maply4 小时前
VSCode 中的 Git Graph扩展使用详解
ide·git·vscode·编辑器·扩展
komo莫莫da4 小时前
寒假刷题Day19
java·开发语言
小小虫码5 小时前
项目中用的网关Gateway及SpringCloud
spring·spring cloud·gateway
计算机-秋大田5 小时前
基于微信小程序的电子竞技信息交流平台设计与实现(LW+源码+讲解)
spring boot·后端·微信小程序·小程序·课程设计
S-X-S5 小时前
算法总结-数组/字符串
java·数据结构·算法