首页 > 编程语言 >Java根据模板生成excel文件【EasyExcel】【xls、xlsx】

Java根据模板生成excel文件【EasyExcel】【xls、xlsx】

时间:2024-03-20 11:27:26浏览次数:35  
标签:Java EasyExcel excel private import HistoryData com response 模板

本文章参考:
作者:   原文链接:https://blog.csdn.net/qq_42761569/article/details/119025171

1、简介
如下图所示,template目录下是准备好的模板,export目录下是生成数据文件。我们这里以第一个模板《theUser蒸汽历史数据.xls》为例进行测试,theUser为占位符,生成的文件中会被替换成对应的用户名。

我这里的代码逻辑是根据选取的用户、起始时间导出用户的历史数据,一个用户一个excel文件,所有用户数据文件在一个目录下,最后把这个目录再压缩成zip,最后用户点击导出的就是这个压缩文件。
———————————————

 提示:红色框框都是使用到的,其它的不用管,这里使用的 EasyExcel 所以需要引入依赖:如下

 <!-- knife4j -->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>knife4j-spring-boot-starter</artifactId>
            <version>3.0.3</version>
        </dependency>

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

 

2、模板格式

占位符这里分两种:

  • {字段名} :{theUser} 和 {reportDate}
  • {自定义名称.字段名}:数据类字段占位符,字段对应entity文件夹中的HistoryData对象的字段,hisData在代码中定义。

 HistoryData对象:如下

package com.example.fengqing.ExcelTemplates.entity;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * @author FengQing
 * @program fengqing
 * @description
 * @date 2024/03/19
 */
@AllArgsConstructor
@NoArgsConstructor
@Data
@Builder
public class HistoryData {

    // 时间
    private String time;

    // 温度
    private Double temp;

    // 压力
    private Double press;

    // 瞬时流量
    private Double insFlow;

    // 累计流量
    private Double accFlow;

    // 瞬时热量
    private Double insHeat;

    // 累计热量
    private Double accHeat;
}

 

3、这里为方便没有编写impl业务层,直接写在Controller 层(一般情况下不建议在Controller层写业务

 

package com.example.fengqing.ExcelTemplates.controller;

import cn.hutool.core.date.DateUtil;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.metadata.fill.FillConfig;
import com.alibaba.excel.write.metadata.fill.FillWrapper;
import com.example.fengqing.ExcelTemplates.ExcelGenerator;
import com.example.fengqing.ExcelTemplates.entity.HistoryData;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author FengQing
 * @program fengqing
 * @description
 * @date 2024/03/20
 */
@Slf4j
@RestController
@RequestMapping("/template")
public class TemplatesController {

    /**
     * 指定模板下载
     * @param response
     * @throws IOException
     */
    @PostMapping("/downFrozenTemplate")
    public void downFrozenTemplate(HttpServletResponse response) throws IOException {
        try {
            String reportDate = DateUtil.date().toString("yyyy年MM月dd日");
       // 获取resources/templates目录下的模板文件 InputStream templateStream = TemplatesController.class.getResourceAsStream("/templates/theUser蒸汽历史数据.xlsx"); if (templateStream == null) { throw new FileNotFoundException("未找到模板文件"); } String resultFileName = "蒸汽模板.xlsx"; // 生成目标文件 ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).withTemplate(templateStream).build(); WriteSheet writeSheet = EasyExcel.writerSheet().build(); // 每次都会重新生成新的一行,而不是使用下面的空行 FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build(); // 替换第一种占位符 Map<String, Object> map = new HashMap<>(); map.put("theUser", "测试有限公司"); map.put("reportDate", reportDate); excelWriter.fill(map, writeSheet); // 第二种占位符替换,这里定义了 hisData excelWriter.fill(new FillWrapper("thsData", hisData()), fillConfig, writeSheet); excelWriter.finish(); // 设置响应头 response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); response.setCharacterEncoding("utf-8"); response.setHeader("Content-Disposition", "attachment; filename=\"" + resultFileName + "\""); // 关闭模板流 templateStream.close(); } catch (FileNotFoundException e) { // 处理文件未找到异常 response.setStatus(HttpServletResponse.SC_NOT_FOUND); // 返回适当的错误消息 response.getWriter().write("未找到模板文件"); } catch (Exception e) { // 处理其他异常 response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR); // 返回适当的错误消息 response.getWriter().write("内部服务器错误"); } } private static List<HistoryData> hisData(){ List<HistoryData> resList = new ArrayList<>(); String today = DateUtil.now(); String yesterday = DateUtil.yesterday().toString(); HistoryData yesData = HistoryData.builder() .time(today) .temp(34.211) .press(1.222) .insFlow(34.211) .accFlow(233.125) .insHeat(20.532) .accHeat(112.562) .build(); HistoryData nowData = HistoryData.builder() .time(yesterday) .temp(34.211) .press(1.222) .insFlow(34.211) .accFlow(233.125) .insHeat(20.532) .accHeat(112.562) .build(); resList.add(yesData); resList.add(nowData); return resList; } }

 

 4、以上代码已完成,接下来使用 postman 来测试,如图:

 

5、最终效果:

 

 

 

标签:Java,EasyExcel,excel,private,import,HistoryData,com,response,模板
From: https://www.cnblogs.com/springclout/p/18084817

相关文章

  • 基于Js和Java实现xlsx\xls文档的导入和下载
    基于Js和Java+MyBatis实现xlsx\xls文档的导入下载、导出背景:​ 实现xlsx\xls文档的导入、导出​ 导入效果:​ 导出效果:导出效果图1、导入、下载1.1、前台<divstyle="margin-left:15px"><inputtype="file"id="selectFile"name="selectFile"/>......
  • Python基于Excel生成矢量图层及属性表信息:ArcPy
      本文介绍基于Python中ArcPy模块,读取Excel表格数据并生成带有属性表的矢量要素图层,同时配置该图层的坐标系的方法。1任务需求  首先,我们来明确一下本文所需实现的需求。  现有一个记录北京市部分PM2.5浓度监测站点信息的Excel表格数据,格式为.xls;文件内包含站点编号、X......
  • 深入理解Java双冒号(::)运算符的使用
    Jdk8中有好多新的特性,比如引入Lambda,简化代码的书写等等我们先看一个关于Lambda的使用 /***输出list*/@Testpublicvoidtest(){String[]array={"aaaa","bbbb","cccc"};List<String>list=Arrays.asList(array);//Java7for(......
  • springboot/java/php/node/python情侣空间微信小程序【计算机毕设】
    本系统(程序+源码)带文档lw万字以上  文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义选题背景:在当今社会,随着科技的迅猛发展和智能移动设备的普及,人们的社交方式正在经历着翻天覆地的变化。特别是年轻情侣之间,他们更倾向于通过数字化平台来表达情感......
  • springboot/java/php/node/python企业内部订餐小程序【计算机毕设】
    本系统(程序+源码)带文档lw万字以上  文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义选题背景:随着互联网科技的飞速发展,企业运营模式正逐步向数字化、智能化方向转型。在这一背景下,企业内部服务流程的优化变得尤为重要。订餐作为企业日常工作中不可......
  • JAVASE各模块结构图:面向对象、常用类、多线程、异常、IO流、集合、网络编程
    ......
  • 230_解决 | idea导航查看源码时总是出现 .class而不是 .java源码
    转载:https://www.yuque.com/yxrpangyu/kls5lq/sg8sh01、File-->Settings-->Maven-->importing(勾选上Sources和Documentation)2、右键项目的pom.xml-->Maven–>Reimport3、窗口右边点击MavenProjects完成下图操作下载即可注意:在下载的时候要保证你的电脑有网络。转换......
  • VBA读取 Excel 并按工作表拆分成多个 Excel
    新建窗体SubSplitExcelByMonth()'OnErrorGoToErrorHandler'启用错误处理OnErrorResumeNextApplication.ScreenUpdating=FalseApplication.DisplayAlerts=FalseDimexclePath,sourceSheetName,groupSheetName,filterI......
  • 深入浅出Java多线程(十三):阻塞队列
    引言大家好,我是你们的老伙计秀才!今天带来的是[深入浅出Java多线程]系列的第十三篇内容:阻塞队列。大家觉得有用请点赞,喜欢请关注!秀才在此谢过大家了!!!在多线程编程的世界里,生产者-消费者问题是一个经典且频繁出现的场景。设想这样一个情况:有一群持续不断地生产资源的线程(我们称之......
  • Java学习笔记:异常处理
    目录Java学习笔记:异常处理什么是异常异常体系结构:Error、Exception自定义异常Java学习笔记:异常处理​ **2024/3/19**什么是异常异常体系结构:Error、Exception自定义异常......