首页 > 其他分享 >springboot+easypoi模板导出Excel 动态表头+多表格(一个sheet)

springboot+easypoi模板导出Excel 动态表头+多表格(一个sheet)

时间:2022-10-27 15:24:06浏览次数:62  
标签:p3 p1 sheet springboot p4 p5 private 武汉市 表头

1.需求:将此页面的几个表格导出

在这里插入图片描述
其中表头中的仓库 集散地是是动态生成的。
首先制作Excel模板:
在这里插入图片描述
代码:

@Resource
	private RedisService redisService;
	@Override
	public void assignModel(EventInfo info, HttpServletResponse response) {
		AssginModelRes res=new AssginModelRes();
    	Object obj = redisService.getObj("modelExport-"+info.getId());
		if (null == obj) {
			throw new CustomException("找不到指定的事件!");
		}
		res = (AssginModelRes) obj;
    	try {
            // 获取workbook对象
            // 单sheet或多sheet 只需要更改此处即可
            Workbook workbook = exportAssignModelByTemplate(res) ;
            // 设置excel的文件名称
            String excelName = "资源分配模型" ;
            // 重置响应对象
            response.reset();
            // 当前日期,用于导出文件名称
            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
            String dateStr = "["+excelName+"-"+sdf.format(new Date())+"]";
            // 指定下载的文件名--设置响应头
            response.setHeader("Content-Disposition", "attachment;filename=" +dateStr+".xls");
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Pragma", "no-cache");
            response.setHeader("Cache-Control", "no-cache");
            response.setDateHeader("Expires", 0);
            // 写出数据输出流到页面
            OutputStream output = response.getOutputStream();
            BufferedOutputStream bufferedOutPut = new BufferedOutputStream(output);
            workbook.write(bufferedOutPut);
            bufferedOutPut.flush();
            bufferedOutPut.close();
            output.close();
        } catch (IOException e) {
            e.printStackTrace();
        }

	}
private Workbook exportAssignModelByTemplate(AssginModelRes res) throws IOException {
	        // 手动创建导出数据,需根据具体业务进行查询 
	        // sheet1内容
	        Map<String,Object> map = new HashMap<String, Object>() ;
	        map.put("w1", res.getT1().getT1header().get(0)); 
	        map.put("w2", res.getT1().getT1header().get(1)); 
	        map.put("w3", res.getT1().getT1header().get(2));    
	        map.put("resultList1",res.getT1().getData());
	        for(int i=0;i<res.getT2().getT2header().size();i++) {
	        	 map.put("p"+(i+1), res.getT2().getT2header().get(i));
	        }
	        map.put("resultList2",res.getT2().getData());
	        map.put("resultList3",res.getT3().getData());
	        map.put("resultList4_1",res.getT4().get(0).getData());
	        map.put("resultList4_2",res.getT4().get(1).getData());
	        map.put("resultList4_3",res.getT4().get(2).getData());
	        // 设置导出配置
	        // 获取导出excel指定模版
			TemplateExportParams template = new TemplateExportParams("templates/model.xls", true);
	        // 导出excel
	        return ExcelExportUtil.exportExcel(template , map);
	    }

主要是在exportAssignModelByTemplate方法内创建map将数据动态地塞进模板里,数据实体类AssginModelRes 为

package cn.com.reformer.model.comandestimate.assignmodel;

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

import lombok.Data;
@Data
public class AssginModelRes implements Serializable{

	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/**
	 * 表格1
	 */
	private Table1 t1;
	/**
	 * 表格2
	 */
	private Table2 t2;
	/**
	 * 表格3
	 */
	private Table3 t3;
	/**
	 * 表格4
	 */
	private List<Table4> t4;
	
}

@Data
public class Table1 implements Serializable {

	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/*
	 * 表头 最近的三个仓库
	 */
	private List<String> t1header;
	/**
	 * 表格数据
	 */
	private List<Table1Data> data;
	
}

@Data
public class Table2 implements Serializable {

	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/**
	 * 表头:事件和次生事件的地点.
	 * 
	 * 
	 */
	private  List<String> t2header;
	private List<Map<String, Object>> data;
	
}
@Data
public class Table3 implements Serializable {

	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/*
	 * 表头
	 */
	private List<String> t3header;
	private List<Map<String, Object>> data;

}
/*
 * 表4:分配结果
 */
@Data
public class Table4 implements Serializable {

	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	/*
	 * 表头:仓库名、集散地
	 */
	private Table4Header header;
	private List<Map<String, Object>> data;
}

数据格式示例:

{
    "msg": "操作成功",
    "code": 200,
    "data": {
        "t1": {
            "t1header": [
                "1209测试仓库",
                "研判测试仓库",
                "测试仓库"
            ],
            "data": [
                {
                    "time": "2020-09-03 19:27:17",
                    "w1": 20,
                    "w2": 14,
                    "w3": 29,
                    "sum": 63
                },
                {
                    "time": "2020-09-03 20:27:17",
                    "w1": 15,
                    "w2": 11,
                    "w3": 20,
                    "sum": 46
                },
                {
                    "time": "2020-09-03 21:27:17",
                    "w1": 27,
                    "w2": 21,
                    "w3": 43,
                    "sum": 91
                }
            ]
        },
        "t2": {
            "t2header": [
                "湖北省武汉市洪山区东湖风景区街道花城大道",
                "湖北省武汉市洪山区和平街道悠贝·菁华幼儿园花样年·花郡东区",
                "湖北省武汉市武昌区徐家棚街街道油料所社区",
                "湖北省武汉市武昌区水果湖街街道万达御湖世家",
                "湖北省武汉市武昌区水果湖街街道观星传媒万达尊"
            ],
            "data": [
                {
                    "time": "2020-09-03 19:27:17",
                    "p1": 21,
                    "p2": 17,
                    "p3": 12,
                    "p4": 15,
                    "p5": 28,
                    "sum": 93
                },
                {
                    "time": "2020-09-03 20:27:17",
                    "p1": 16,
                    "p2": 28,
                    "p3": 9,
                    "p4": 17,
                    "p5": 23,
                    "sum": 93
                },
                {
                    "time": "2020-09-03 21:27:17",
                    "p1": 28,
                    "p2": 30,
                    "p3": 17,
                    "p4": 29,
                    "p5": 21,
                    "sum": 125
                }
            ]
        },
        "t3": {
            "t3header": [
                "湖北省武汉市洪山区东湖风景区街道花城大道",
                "湖北省武汉市洪山区和平街道悠贝·菁华幼儿园花样年·花郡东区",
                "湖北省武汉市武昌区徐家棚街街道油料所社区",
                "湖北省武汉市武昌区水果湖街街道万达御湖世家",
                "湖北省武汉市武昌区水果湖街街道观星传媒万达尊"
            ],
            "data": [
                {
                    "warename": "1209测试仓库",
                    "p1": 1.26,
                    "p2": 1.05,
                    "p3": 1.37,
                    "p4": 1.5,
                    "p5": 1.31
                },
                {
                    "warename": "研判测试仓库",
                    "p1": 1.16,
                    "p2": 1.25,
                    "p3": 1.02,
                    "p4": 1.7,
                    "p5": 1.57
                },
                {
                    "warename": "测试仓库",
                    "p1": 1.53,
                    "p2": 1.29,
                    "p3": 1.07,
                    "p4": 1.15,
                    "p5": 1.08
                }
            ]
        },
        "t4": [
            {
                "header": {
                    "ware1": "1209测试仓库",
                    "places": [
                        "湖北省武汉市洪山区东湖风景区街道花城大道",
                        "湖北省武汉市洪山区和平街道悠贝·菁华幼儿园花样年·花郡东区",
                        "湖北省武汉市武昌区徐家棚街街道油料所社区",
                        "湖北省武汉市武昌区水果湖街街道万达御湖世家",
                        "湖北省武汉市武昌区水果湖街街道观星传媒万达尊"
                    ]
                },
                "data": [
                    {
                        "p0": "实际需求dj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "实际需求zj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "分配量∑χφ(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "满意度Rj(t)",
                        "p1": 0.62,
                        "p2": 0.59,
                        "p3": 0.68,
                        "p4": 0.6,
                        "p5": 0.61
                    }
                ]
            },
            {
                "header": {
                    "ware1": "研判测试仓库",
                    "places": [
                        "湖北省武汉市洪山区东湖风景区街道花城大道",
                        "湖北省武汉市洪山区和平街道悠贝·菁华幼儿园花样年·花郡东区",
                        "湖北省武汉市武昌区徐家棚街街道油料所社区",
                        "湖北省武汉市武昌区水果湖街街道万达御湖世家",
                        "湖北省武汉市武昌区水果湖街街道观星传媒万达尊"
                    ]
                },
                "data": [
                    {
                        "p0": "实际需求dj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "实际需求zj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "分配量∑χφ(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "满意度Rj(t)",
                        "p1": 0.62,
                        "p2": 0.59,
                        "p3": 0.68,
                        "p4": 0.6,
                        "p5": 0.61
                    }
                ]
            },
            {
                "header": {
                    "ware1": "测试仓库",
                    "places": [
                        "湖北省武汉市洪山区东湖风景区街道花城大道",
                        "湖北省武汉市洪山区和平街道悠贝·菁华幼儿园花样年·花郡东区",
                        "湖北省武汉市武昌区徐家棚街街道油料所社区",
                        "湖北省武汉市武昌区水果湖街街道万达御湖世家",
                        "湖北省武汉市武昌区水果湖街街道观星传媒万达尊"
                    ]
                },
                "data": [
                    {
                        "p0": "实际需求dj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "实际需求zj(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "分配量∑χφ(t)",
                        "p1": 21,
                        "p2": 17,
                        "p3": 12,
                        "p4": 15,
                        "p5": 28
                    },
                    {
                        "p0": "满意度Rj(t)",
                        "p1": 0.62,
                        "p2": 0.59,
                        "p3": 0.68,
                        "p4": 0.6,
                        "p5": 0.61
                    }
                ]
            }
        ]
    }
}

最终导出的Excel 为:
在这里插入图片描述

标签:p3,p1,sheet,springboot,p4,p5,private,武汉市,表头
From: https://www.cnblogs.com/yelanggu/p/16832344.html

相关文章

  • Springboot centos7 启动
     1、java-jardemo.jar说明:用这种方法启动后,不能继续执行其它命令了,如果想要继续执行其它命令,就都打断,打断一般用ctrl+c。2、java-jardemo.jar&第2种在第1种方式的......
  • SpringBoot AOP异常日志处理 使用AOP+注解的方式进行异常日志的处理
    SpringBootAOP异常日志处理使用AOP+注解的方式进行异常日志的处理最近公司的一个项目需要将异常日志通过企业微信进行告警,由于消息推送已经有异常处理平台进行处理,现在......
  • Springboot项目启动报错UnsatisfiedDependency、NoSuchBeanDefinitionException
    今天做项目的过程中,启动项目突然出现:控制台报错Exceptionencounteredduringcontextinitialization-cancellingrefreshattempt:org.springframework.beans.fact......
  • Handsontable合并表头,实现rowspan效果
    背景使用handsontable只能进行跨列的合并,如果跨行的话就有api提供,我们需要对表头进行跨行合并实现这里学习这边博文提供的一个思路,就是假设需要对表格第一行的跨行合并......
  • hyperf/go/springboot通过jsonrpc通信
    一、背景随着用户的增长和业务的增多,单节点服务已经满足不了需求,用hyperf对主业务进行了重构。hyperf是一个后现代的php框架,基于php+swoole,支持协程,解决了php让人诟病的......
  • Springboot和mybatis-plus支持多数据源(多数据库)
    1、pom添加依赖<dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>3.5.1</version></de......
  • 搭建基本的springboot框架
    <?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"......
  • SpringBoot启动过程(二)
    ​​上一篇​​https://blog.51cto.com/u_15815563/5787667​​说到设置了初始化器。设置listener现在,同样的一套流程,这次要实例化的是实现了ApplicationListener的类,并存......
  • Springboot 一行代码实现文件上传 20个平台!少写代码到极致
    又是做好人好事的一天,有个小可爱私下问我有没有好用的springboot文件上传工具,这不巧了嘛,正好我私藏了一个好东西,顺便给小伙伴们也分享一下,demo地址放在文末了。文件上传......
  • SpringBoot配置RabbitMQ
    一、导入Maven依赖<!--Springboot父依赖--><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-......