EasyPoi

EasyPoi

使用模板导出数据

1.引入依赖

        <dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-spring-boot-starter</artifactId><version>4.2.0</version></dependency>

2.工具类

package com.junfeng.utils;import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.ExcelImportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams;
import cn.afterturn.easypoi.excel.entity.ImportParams;
import cn.afterturn.easypoi.excel.entity.enmus.ExcelType;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.usermodel.Workbook;
import org.springframework.web.multipart.MultipartFile;import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;/*** Excel工具类*/
public class ExcelUtil {/*** 导出** @param list           数据列表* @param title          标题* @param sheetName      sheet名称* @param pojoClass      元素类型* @param fileName       文件名* @param isCreateHeader 是否创建列头*/public static void exportExcel(List<?> list, String title, String sheetName, Class<?> pojoClass, String fileName, boolean isCreateHeader, HttpServletResponse response) throws IOException {ExportParams exportParams = new ExportParams(title, sheetName, ExcelType.XSSF);exportParams.setCreateHeadRows(isCreateHeader);defaultExport(list, pojoClass, fileName, response, exportParams);}/*** 导出** @param list      数据列表* @param title     标题* @param sheetName sheet名称* @param pojoClass 元素类型* @param fileName  文件名*/public static void exportExcel(List<?> list, String title, String sheetName, Class<?> pojoClass, String fileName, HttpServletResponse response) throws IOException {defaultExport(list, pojoClass, fileName, response, new ExportParams(title, sheetName, ExcelType.XSSF));}/*** 导出,适用于导出多个sheet的Excel,配合createOneSheet方法一起使用** @param list     数据列表(元素是Map)* @param fileName 文件名*/public static void exportExcel(List<Map<String, Object>> list, String fileName, HttpServletResponse response) throws IOException {defaultExport(list, fileName, response);}/*** 导入*/public static <T> List<T> importExcel(String filePath, Integer titleRows, Integer headerRows, Class<T> pojoClass) {if (StringUtils.isBlank(filePath)) {return Collections.emptyList();}ImportParams params = new ImportParams();params.setTitleRows(titleRows);params.setHeadRows(headerRows);return ExcelImportUtil.importExcel(new File(filePath), pojoClass, params);}public static <T> List<T> importExcel(MultipartFile file, Integer titleRows, Integer headerRows, Class<T> pojoClass) throws Exception {if (file == null) {return Collections.emptyList();}ImportParams params = new ImportParams();params.setTitleRows(titleRows);params.setHeadRows(headerRows);return ExcelImportUtil.importExcel(file.getInputStream(), pojoClass, params);}/*** 功能描述:根据接收的Excel文件来导入多个sheet,根据索引可返回一个集合** @param file       导入文件* @param sheetIndex 导入sheet索引,从0开始* @param titleRows  表标题的行数* @param headerRows 表头行数* @param pojoClass  Excel实体类*/public static <T> List<T> importExcel(MultipartFile file, int sheetIndex, Integer titleRows, Integer headerRows, Class<T> pojoClass) throws Exception {if (file == null) {return Collections.emptyList();}// 根据file得到Workbook,主要是要根据这个对象获取,传过来的excel有几个sheet页ImportParams params = new ImportParams();// 第几个sheet页params.setStartSheetIndex(sheetIndex);params.setTitleRows(titleRows);params.setHeadRows(headerRows);return ExcelImportUtil.importExcel(file.getInputStream(), pojoClass, params);}/*** 功能描述:根据接收的Excel文件来导入多个sheet,根据索引可返回一个集合** @param filePath   导入文件路径* @param sheetIndex 导入sheet索引* @param titleRows  表标题的行数* @param headerRows 表头行数* @param pojoClass  Excel实体类*/public static <T> List<T> importExcel(String filePath, int sheetIndex, Integer titleRows, Integer headerRows, Class<T> pojoClass) {ImportParams params = new ImportParams();params.setStartSheetIndex(sheetIndex);params.setTitleRows(titleRows);params.setHeadRows(headerRows);return ExcelImportUtil.importExcel(new File(filePath), pojoClass, params);}/*** 用于导出多sheet的Excel文件** @param sheetName 自定义sheetName* @param clazz     pojo实体类* @param data      List<Map<String, Object>> or List<POJO>* @return map*/public static Map<String, Object> createOneSheet(String sheetName, Class<?> clazz, List<?> data) {ExportParams params = new ExportParams("", sheetName, ExcelType.XSSF);return createOneSheet(params, clazz, data);}/*** 创建一个表格并填充内容,返回map供工作簿使用,map的key必须写死** @param params 导出配置* @param clazz  带@Excel注解字段的POJO实体类* @param data   List<Map<String, Object>> or List<POJO>* @return map*/private static Map<String, Object> createOneSheet(ExportParams params, Class<?> clazz, List<?> data) {Map<String, Object> map = new HashMap<>(8);map.put("title", params);map.put("entity", clazz);map.put("data", data);return map;}private static void defaultExport(List<?> list, Class<?> pojoClass, String fileName, HttpServletResponse response, ExportParams exportParams) throws IOException {Workbook workbook = ExcelExportUtil.exportExcel(exportParams, pojoClass, list);if (workbook != null) {downLoadExcel(fileName, response, workbook);}}private static void defaultExport(List<Map<String, Object>> list, String fileName, HttpServletResponse response) throws IOException {Workbook workbook = ExcelExportUtil.exportExcel(list, ExcelType.XSSF);if (workbook != null) {downLoadExcel(fileName, response, workbook);}}public static void downLoadExcel(String fileName, HttpServletResponse response, Workbook workbook) throws IOException {response.setCharacterEncoding("UTF-8");response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8"));workbook.write(response.getOutputStream());}
}

3.导出代码

 @Overridepublic void export(List<StorageCapacityVO> result, HttpServletResponse response) throws IOException {TemplateExportParams params = new TemplateExportParams("doc/example.xlsx");Map<String, Object> map = new HashMap<>();List<Map<String, String>> listMap = new ArrayList<>();String yyyymm = "";String dd = "";for (int i = 0; i < result.size(); i++) {Map<String, String> lm = new HashMap<>();StorageCapacityVO vo = result.get(i);Date tm = vo.getTm();dd = DateUtil.format(tm, "dd");String time = DateUtil.format(tm, "HH:mm:ss");yyyymm = DateUtil.format(tm, "yyyy 年 MM 月");lm.put("time", time == null ? "" : time);lm.put("water", vo.getWater() == null ? "" : vo.getWater() + "");lm.put("power", vo.getPower() == null ? "" : vo.getPower() + "");lm.put("ecologyFlow", vo.getEcologyFlow() == null ? "" : vo.getEcologyFlow() + "");lm.put("downFlow", vo.getDownFlow() == null ? "" : vo.getDownFlow() + "");lm.put("warehousing", vo.getWarehousing() == null ? "" : vo.getWarehousing() + "");lm.put("q", vo.getQ() == null ? "" : vo.getQ() + "");lm.put("z", vo.getZ() == null ? "" : vo.getZ() + "");listMap.add(lm);}map.put("maplist", listMap);map.put("yyyymm", yyyymm);map.put("dd", dd);Workbook workbook = ExcelExportUtil.exportExcel(params, map);/*//导出文件到本地File savefile = new File("D:/excel/");if (!savefile.exists()) {savefile.mkdirs();}FileOutputStream fos = new FileOutputStream("D:/excel/水位记录表_map.xls");workbook.write(fos);fos.close();*/String fileName = "file_" + dd + ".xlsx";//返回二进制流给前端downLoadExcel(fileName, response, workbook);}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/120124.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 图片和文本生成新的图片(Canvas)

一、需求描述 项目有个需求需要在全屏图片上展示文字并生成一个新的图片并分享出去&#xff0c;图片全屏&#xff0c;文字居中。 于是便想到了使用Canvas来直接进行绘制。 二、实现代码 private fun createImg(imageView: ImageView, textView: TextView): Bitmap {//返回具…

如何在群晖NAS中搭建WebDav服务,并实现公网访问

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏:《速学数据结构》 《C语言进阶篇》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 1. 在群晖套件中心安装WebDav Server套件1.1 安装完成后&#xff0c;启动webdav服务&#xff0c;并勾选HTTP复选…

物流数字化转型有什么意义?

物流领域的数字化转型具有深远的意义&#xff0c;因为它彻底改变了供应链中的货物和信息流动方式。这一转变是由数字技术集成推动的&#xff0c;旨在提高效率、可见性和客户满意度。以下是其重要性的一些关键方面&#xff1a; 1.提高效率和降低成本&#xff1a;数字化转型通过…

使用了lua-resty-http库进行 爬虫

lua-resty-http是一个基于OpenResty的HTTP客户端库&#xff0c;用于在Lua中进行HTTP请求和响应的处理。它提供了简单易用的接口&#xff0c;可以方便地进行网页抓取和爬虫开发。 使用lua-resty-http进行爬虫&#xff0c;需要先安装OpenResty和lua-resty-http库&#xff0c;并将…

Hadoop 请求数据长度 Requested Data length 超过配置的最大值

一、问题 现象 Spark 任务速度变慢&#xff0c;也不失败。 DataNode 内存足够 CPU 负载不高 GC 时间也不长。 查看 DataNode 日志&#xff0c;发现有些日志出现很多 Netty RPC 超时。超时的 destination 是一个 NameNode 节点&#xff0c;然后查看 NameNode 节点的日志&…

Java支付宝沙箱环境支付,官方Demo远程调试【内网穿透】

文章目录 前言1. 下载当面付demo2. 修改配置文件3. 打包成web服务4. 局域网测试5. 内网穿透6. 测试公网访问7. 配置二级子域名8. 测试使用固定二级子域名访问 前言 在沙箱环境调试支付SDK的时候&#xff0c;往往沙箱环境部署在本地&#xff0c;局限性大&#xff0c;在沙箱环境…

Unity的碰撞检测(四)

温馨提示&#xff1a;本文基于前一篇“Unity的碰撞检测(三)”继续探讨两个游戏对象具备刚体的触发检测&#xff0c;阅读本文则默认已阅读前文。 &#xff08;一&#xff09;测试说明 在基于两个游戏对象都具备触发器和刚体且属性一致的条件下&#xff0c;若二者刚体的BodyType…

分布式日志和链路追踪

分布式日志 实现思路 分布式日志框架服务的实现思路基本是一致的&#xff0c;如下&#xff1a; 日志收集器&#xff1a;微服务中引入日志客户端&#xff0c;将记录的日志发送到日志服务端的收集器&#xff0c;然后以某种方式存储数据存储&#xff1a;一般使用ElasticSearch分…

【Mybatis源码】XMLConfigBuilder构建器 - 读取XML配置初始化Configuration对象

XMLConfigBuilder是Mybatis中定义的进行构建Configuration对象的类,此类用于读取XML配置文件创建并初始化Configuration对象; 上一篇中我们介绍了XMLConfigBuilder构建器加载XML配置文件以及创建Configuration对象https://blog.csdn.net/m1729339749/article/details/133983…

护眼灯买哪种好? 推荐五款儿童护眼台灯

台灯如何选择&#xff0c;随着人们生活水平的提高及科技的不断进步&#xff0c;台灯的品质也得到了极大的提高&#xff0c;在生活中很多时候都需要使用台灯&#xff0c;但是市面上的台灯那么多&#xff0c;台灯如何选择。本次小编为大家推荐五款好用的护眼灯。 1.书客护眼台灯L…

LeetCode 面试题 16.01. 交换数字

文章目录 一、题目二、C# 题解 一、题目 编写一个函数&#xff0c;不用临时变量&#xff0c;直接交换 numbers [a, b] 中 a 与 b 的值。 示例&#xff1a; 输入: numbers [1,2] 输出: [2,1] 提示&#xff1a; numbers.length 2-2147483647 < numbers[i] < 214748364…

NDK交叉编译FFmpeg安卓编译ffmpeg

NDK交叉编译FFmpeg安卓编译ffmpeg 文章目录 NDK交叉编译FFmpeg安卓编译ffmpeg编译环境编译工具下载 编译过程编译环境系统环境NDK版本的选择 源码下载只编译简单的ffmpeg编译编译脚本问题 使用技术支持 编译环境 编译工具下载 参考这个&#xff1a;https://blog.csdn.net/gao…

NodeRed 配置 Modbus

2023-10-27 点右上角添加之后&#xff0c;选择这个服务。为了好记。我把名称改成了&#xff1a;127.0.0.1:502 点右上角[完成] 出来了

如何在filters中使用data中数据?

在vue2.x中使用filters功能,如果想在filter中使用this调用data中的数据,会报错,因为this不是指向vue组件实例。 如果想用data中的数据,一般有两种方式: 1.在使用filter时传入data中数据,如: <template> <div> 目前选择的是:{{ type | convertText…

做外贸要时常做复盘总结

外贸的工作其实是阶段性的&#xff0c;所谓的阶段性就是有的时候客户可能会扎堆的出现。然后一天的工作几乎都是在和各个客户沟通中度过&#xff0c;比如报价&#xff0c;做表格等等&#xff0c;然后就会觉得这一天过的很快&#xff0c;也很充实。 然而实质上当我们回顾这一天…

70 搜索插入位置

搜索插入位置 题解1 二分查找防越界写法 题解2 STL大法两行 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c; 并返回其索引。如果目标值不存在于数组中&#xff0c; 返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O ( l o g n ) O(log n…

node开发微信群聊机器人第⑤章

▍PART 序 看本文时&#xff0c;请确保前4章都已经看过&#xff0c;不然本章你看着看着思维容易跳脱&#xff01;再一个机器人教程只在公众号&#xff1a;“程序员野区”首发。csdn会跟着发一份&#xff0c;未经博主同意&#xff0c;请勿转载&#xff01;欢迎分享到自己的微信…

记一次EasyExcel导出时将空格丢失的问题

EasyExcel的issues可以看到 需求&#xff1a;导出的数据以树形展示&#xff0c;如下&#xff1a; 导出结果&#xff1a; 原因&#xff1a; EasyExcel会默认去除掉空格&#xff0c;autoTrim熟悉默认为true&#xff0c;只需要设置为false即可。

Kafka-Java二:Spring实现kafka消息发送的ack机制

写在前面 如果只有一个kafka实例的话&#xff0c;那么文章中提到kafka集群kafka实例 一、什么是消息发送者端的ack机制 ack机制&#xff1a;消息确认发送成功的标识 由谁发起该标识&#xff1a;kafka集群 发起该标识的场景&#xff1a;kafka集群确认已经收到了消息。 由谁接收…

低代码软件的价格考量:成本效益与投资回报

数字化转型的今天&#xff0c;我们常听到“低代码”这个概念&#xff0c;那低代码软件价格到底如何呢&#xff1f;很多厂商并没有公布软件价格情况&#xff0c;让很多企业在采购的时候也是一头雾水。当然&#xff0c;市场上也存在一些厂商公开透明价格&#xff0c;比如Zoho Cre…