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 为:

springboot+easypoi模板导出Excel 动态表头+多表格(一个sheet)的更多相关文章

  1. JAVA POI导出EXCEL 动态表头、多级表头、动态数据

    导出Excel文件是业务中经常遇到的需求,以下是经常遇到的一些问题: 1,导出中文文件名乱码 String filename = "sheet1";response.setChar ...

  2. 根据模板导出Excel报表并生成多个Sheet页

    因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为  根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...

  3. Java无模板导出Excel,Apache-POI插件实现

    开发环境 jdk 1.8 Maven 3.6 Tomcat 8.5 SpringBoot 2.1.4.RELEASE Apache-POI 3.6 Idea 注意: 我是在现有的基于SpringBoo ...

  4. EasyPOI导入导出Excel

    EasyPOI工具可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 导入maven依赖 <dependency> <group ...

  5. aspose.cells根据模板导出excel

    又隔十多天没写博客了,最近都在忙项目的事情,公司人事变动也比较大,手头上就又多了一个项目.最近做用aspose.cells根据模板导出excel报价单的功能,顺便把相关的核心记下来,先上模板和导出的效 ...

  6. Html Table用JS导出excel格式问题 导出EXCEL后单元格里的000412341234会变成412341234 7-14 会变成 2018-7-14(7月14) 自定义格式 web利用table表格生成excel格式问题 js导出excel增加表头、mso-number-format定义数据格式 数字输出格式转换 mso-number-format:"\@"

    Html Table用JS导出excel格式问题 我在网上找的JS把HTML Tabel导出成EXCEL.但是如果Table里的数字内容为0开的的导成Excel后会自动删除0,我想以text的格式写入 ...

  7. Vue + axios + SpringBoot 2实现导出Excel

    Vue + axios + SpringBoot 2实现导出Excel 1. 前端js代码-发送Http请求 /** * 文件下载 * @param url 下载地址 * @param fileNam ...

  8. POI通过模板导出EXCEL文件

    一般的EXCEL导出使用POI先创建一个HSSFWorkbook,然后通过不断创建HSSFRow,HSSFCell后设置单元格内容便可以完成导出. 这次在项目中需要用到模板,导出的内容包括(1.模板中 ...

  9. 【每日一点】1. Java如何实现导出Excel单表头或多表头

    一.背景 在后台项目中,经常会遇到将呈现的内容导出到Excel的需求,通过都是导出单个表头的Excel文件,如果存在级联关系的情况下,也就需要导出多表头的场景.今天这篇文章就是分享导出Excel单表头 ...

  10. .Net NPOI 根据excel模板导出excel、直接生成excel

    一.根据Excel模板导出excel 1.导入NPOI.dll  2.DAL中添加类ExportExcel.cs using NPOI.SS.UserModel; using System; usin ...

随机推荐

  1. VTK 设置面片背面颜色

    在上一篇文章切开了零件,发现零件内部和外部颜色一样,当需要不一样时,可以通过actor的SetBackfaceProperty方法设置背面属性. 代码跟上一篇几乎一样,只是给actor设置了SetBa ...

  2. FastExcel 合并单元格(相当的行数据,进行合并)

    目录 需求 思路 实现 Excel导出单元格全量合并策略 日期格式转换 接口代码 Service DTO 使用FastExcel数据导出:官网: https://idev.cn/fastexcel/z ...

  3. showModalBottomSheet setState 无法更新ui和高度设置问题

    showModalBottomSheet setState 无法更新ui问题 首先理解showModalBottomSheet,本质上可以理解为路由入栈,在show之后弹出的页面其实是另一个页面了,此 ...

  4. .NET 8 中的 ASP.NET Core 指标与 Grafana 仪表板入门

    .NET 8 中的 ASP.NET Core 指标与 Grafana 仪表板入门 原文地址:https://devblogs.microsoft.com/dotnet/introducing-aspn ...

  5. 关于 Span 的一切:探索新的 .NET 明星:5. .NET 运行时的处理

    .5. NET 运行时会怎么样? 1. Span<T> 是什么? 2. Span<T> 是如何实现的? 3. 什么是 Memory<T>,以及为什么你需要它? 4. ...

  6. 中电金信通过KCSP认证 云原生能力获权威认可

    ​ 中电金信通过KCSP(Kubernetes Certified Service Provider)认证,正式成为CNCF(云原生计算基金会)官方认证的 Kubernetes 服务提供商. ​ Ku ...

  7. 为什么SQL正在击败NoSQL,这对未来的数据意味着什么(转载)

    为什么SQL正在击败NoSQL,这对未来的数据意味着什么 : http://geek.csdn.net/news/detail/238939 译者注:经过多年的沉寂之后,今天的SQL正在复出.缘由如何 ...

  8. 在app內建web server

    这几年在三家企业都使用 app 內建 web server 的技术方案.效果很好. 该方案顾名思义,就是在 app 中加入一个 embed webserver 组件.组件和app运行于同一进程空间.程 ...

  9. 关于Qt中的qss样式表需要注意的坑

    关于QSS要注意的坑. qss源自css,相当于css的一个子集,主要支持的是css2标准,很多网上的css3的标准的写法在qss这里是不生效的,所以不要大惊小怪. qss也不是完全支持所有的css2 ...

  10. Jetbrains fleet 配置 C++开发环境(基于CMAKE和MinGW)

    Jetbrains fleet 配置 C++开发环境 1. 安装 Jetbrains Fleet 到Fleet下载页面下载Toolbox并安装 Jetbrains-Fleet下载页 安装完成后在任务栏 ...