Excel导出

目录

Maven依赖

实体类

表头列宽自适应处理器

行列冻结处理器

合并单元格处理器

工具类


Maven依赖

        <!--easy excel--><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.3.2</version></dependency><!-- excel工具 --><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version></dependency><!--lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.16.10</version><scope>provided</scope></dependency><!--工具集--><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.12</version></dependency>

实体类


import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import lombok.Data;import java.io.Serializable;
import java.util.Date;/*** entity实体类** @Package_Name * @Author Leslie Lee* @TIME * @Version 1.0*/
@Data
@ExcelIgnoreUnannotated //忽略未标注的字段
public class EntityDemo implements Serializable {private static final long serialVersionUID = 1L;@ExcelProperty("姓名")private String name;//private String age;//@ExcelProperty("申请日期")@DateTimeFormat("yyyy-MM-dd")//时间格式private Date applicationDate;//申请日期}

表头列宽自适应处理器

import com.alibaba.excel.metadata.Head;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.style.column.AbstractColumnWidthStyleStrategy;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Sheet;import java.util.List;/*** 表头自动列宽** @Package_Name * @Author Leslie Lee* @TIME * @Version 1.0*/
public class ExcelWidthStyleStrategy extends AbstractColumnWidthStyleStrategy {// 统计setColumnWidth被调用多少次private static int count = 0;@Overrideprotected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<WriteCellData<?>> cellDataList, Cell cell, Head head,Integer relativeRowIndex, Boolean isHead) {// 简单设置Sheet sheet = writeSheetHolder.getSheet();sheet.setColumnWidth(cell.getColumnIndex(), 5000);}
}

行列冻结处理器

import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import org.apache.poi.ss.usermodel.Sheet;/*** excel导出,冻结列和行 处理器** @Package_Name* @Author Leslie Lee* @TIME* @Version 1.0*/
public class FreezeRowColHandler implements SheetWriteHandler {/*** colSplit:表示要冻结的列数;* rowSplit:表示要冻结的行数;* firstCellNum:表示被固定列右边第一列的列号;* firstRollNum :表示被固定行下边第一列的行号;*/private int colSplit = 0, rowSplit = 1, firstCellNum = 0, firstRollNum = 0;/* 空参构造,不传值默认冻结一行 */public FreezeRowColHandler() {}public FreezeRowColHandler(int colSplit, int rowSplit, int firstCellNum, int firstRollNum) {this.colSplit = colSplit;this.rowSplit = rowSplit;this.firstCellNum = firstCellNum;this.firstRollNum = firstRollNum;}@Overridepublic void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {}@Overridepublic void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {Sheet sheet = writeSheetHolder.getSheet();sheet.createFreezePane(colSplit, rowSplit, firstCellNum, firstRollNum);}
}

合并单元格处理器

import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ReflectUtil;
import cn.hutool.core.util.StrUtil;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import lombok.extern.slf4j.Slf4j;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.util.CellRangeAddress;import java.lang.reflect.Field;
import java.util.List;/*** easyExcel合并单元格** @Package_Name* @Author Leslie Lee* @TIME* @Version 1.0*/
@Slf4j
public class ExcelCellMergeStrategy implements SheetWriteHandler {private List<CellRangeAddress> addressList;public ExcelCellMergeStrategy() {}public ExcelCellMergeStrategy(List<CellRangeAddress> addressList) {this.addressList = addressList;}@Overridepublic void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {}/* 执行合并 */@Overridepublic void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {Sheet sheet = writeSheetHolder.getSheet();//打印合并信息
//        log.info("ExcelCellMergeStrategy|start|合并单元格|sheet名称:{}|开始执行", sheet.getSheetName());for (CellRangeAddress address : addressList) {sheet.addMergedRegionUnsafe(address);}}/*** 合并单元格策略,根据首列相同,合并指定列数** @param mergeColumnIndexes 合并列数 前{x}列* @param tableHeaderRows    表头行数* @param list               导出的数据* @param <T>                导出数据-实体类* @return 合并范围*/public static <T> List<CellRangeAddress> getOneColAddressList(int mergeColumnIndexes, int tableHeaderRows, List<T> list) {List<CellRangeAddress> addressList = CollUtil.newArrayList();if (CollUtil.isNotEmpty(list)) {Class<?> aClass = list.get(0).getClass();Field f = null;Field[] fields = aClass.getDeclaredFields();for (Field field : fields) {if (field.isAnnotationPresent(ExcelProperty.class)) {f = field;break;}}if (f != null) {//list长度,最大行数int size = list.size();//防止下标越界使用int i2 = size - 2;for (int i = 0; i < size; i++) {//开始行 从 不合并标题int firstRow = i + tableHeaderRows;//结束行int lastRow = firstRow;//开始列,结束列//int firstCol,lastCol = 0;String value = StrUtil.toString(ReflectUtil.getFieldValue(list.get(i), f));boolean flag = true;while (flag) {//最后一行不再进行匹配,直接退出if (i > i2) {break;}String value1 = StrUtil.toString(ReflectUtil.getFieldValue(list.get(i + 1), f));//值相同则合并 -> 合并行数+1 下标+1遍历跳过相同行if (StrUtil.equals(value1, value)) {i++;lastRow++;} else {flag = false;}if (i == size) {flag = false;}}if (lastRow != firstRow) {for (int i1 = 0; i1 < mergeColumnIndexes; i1++) {addressList.add(new CellRangeAddress(firstRow, lastRow, i1, i1));}}}}}return addressList;}
}

工具类

import com.alibaba.excel.EasyExcel;import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.List;/*** @Package_Name * @Author Leslie Lee* @TIME * @Version 1.0*/
public class EasyExcelUtils<T> {/*** 分片导出** @param response* @param list* @param sheetName* @throws IOException*/public static void downloadFragmentation2(HttpServletResponse response, List<?> list, String sheetName, int mergeColumnIndexs, int hdrRow) throws IOException {Class<?> clazz = list.get(0).getClass();response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");// URLEncoder.encode 防止中文乱码 和easyexcel没有关系String fileName = URLEncoder.encode(sheetName, "UTF-8").replaceAll("\\+", "%20");response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");// 定义每次写入的数据量int batchSize = 2000;// 定义写入的起始位置int start = 0;// 定义写入的结束位置int end = 0;while (end < list.size()) {// 计算下一次写入的结束位置end = Math.min(start + batchSize, list.size());// 获取本次写入的数据List<?> subList = list.subList(start, end);// 写入数据EasyExcel.write(response.getOutputStream(), clazz)/* 列宽自适应 */.registerWriteHandler(new ExcelWidthStyleStrategy())/* 行列冻结 */.registerWriteHandler(new FreezeRowColHandler())/* 单元格合并 */.registerWriteHandler(new ExcelCellMergeStrategy(getOneColAddressList(mergeColumnIndexs,hdrRow,list))).sheet(sheetName).doWrite(list);// 更新起始位置start = end;}}
}

                                                                Leslie Lee 随笔

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

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

相关文章

数独游戏(dfs)

代码注释如下 #include <iostream> using namespace std; const int N 10; bool col[N][N], rol[N][N], cell[3][3][N]; char g[N][N]; bool dfs(int x, int y) { //用bool这样在找到一个方案就可以迅速退出if(y 9) x, y 0; //若y超出边界&#xff0c;则第二…

S1---FPGA硬件板级原理图实战导学

视频链接 FPGA板级实战导学01_哔哩哔哩_bilibili FPGA硬件板级原理图实战导学 【硬件电路设计的方法和技巧-哔哩哔哩】硬件电路设计的方法和技巧01_哔哩哔哩_bilibili&#xff08;40min&#xff09; 【高速板级硬件电路设计-哔哩哔哩】 高速板级硬件电路设计1_哔哩哔哩_bil…

【RT-Thread基础教程】邮箱的使用

文章目录 前言一、邮箱的特性二、邮箱操作函数2.1 创建邮箱创建动态邮箱创建静态邮箱 2.2 删除邮箱2.3 发邮件2.4 取邮件 三、示例代码总结 前言 RT-Thread是一个开源的实时嵌入式操作系统&#xff0c;广泛应用于各种嵌入式系统和物联网设备。在RT-Thread中&#xff0c;邮箱是…

输入一个整数,输出其最长连续因子。

输入一个整数&#xff0c;输出其最长连续因子。 例如 输入&#xff1a;60 输出&#xff1a;2 3 4 5 6 注意&#xff1a;1不算因子 输入输出格式 输入描述: 输入一个整数N&#xff0c;N<10000。 输出描述: 输出其最长连续因子&#xff0c;如果有多个最长&#xff0c;输出…

HTML5浮动

1.标准文档流组成 块级元素&#xff08;block&#xff09; 内联元素&#xff08;inline&#xff09; 2.display属性 作用&#xff1a;指定HTML标签的显示方式 常用属性 值 说明 block 块级元素的默认值&#xff0c;元素会被显示为块级元素&#xff0c;该元素前后会带有换行…

Linux UnixODBC安装配置

配置 UnixODBC 梦之上关注IP属地: 香港 0.2322020.12.09 13:23:10字数 1,202阅读 5,447 麒麟&达梦适配系列: 1.麒麟服务器上安装 DM8 2.配置 UnixODBC 3.beego-ORM 适配达梦 资源紧张的时候&#xff0c;服务器是大家共用的&#xff0c;上面部署了一堆服务。所以选用doc…

Lua速成(7)

一、Lua 元表(Metatable) 在 Lua table 中我们可以访问对应的 key 来得到 value 值&#xff0c;但是却无法对两个 table 进行操作(比如相加)。 因此 Lua 提供了元表(Metatable)&#xff0c;允许我们改变 table 的行为&#xff0c;每个行为关联了对应的元方法。 例如&#xf…

ShardingJdbc实战-分库分表

文章目录 基本配置分库分表的分片策略一、inline 行表达时分片策略algorithm-expression行表达式完整案例和配置如下 二、根据实时间日期 - 按照标准规则分库分表标准分片 - Standard完整案例和配置如下 基本配置 逻辑表 逻辑表是指&#xff1a;水平拆分的数据库或者数据表的相…

SpringBoot实战(1)

SpringBoot总结 一,Spring 设计思想 OOP: 面向对象编程-》封装、继承、多态 BOP: 面向Bean编程-》一切从Bean开始 AOP: 面向切面编程-》解藕、专 人做专事 IOC: 控制反转,将new 对象的操作交给Spring统一管理-》转交控制权 DI/DL: 依赖注入/依赖查找-》自动赋值 DI和AOP…

LLVM 一些重要文档 LLVM 3.0

基于LLVM 3.0: Documentation for the LLVM System at SVN head LLVM 作为库的使用方法&#xff1a; Using The LLVM Libraries LLVM C 的编程规范&#xff1a; LLVM Coding Standards

stl 迭代器(Iterator)

定义 迭代器&#xff08;Iterator&#xff09;是STL&#xff08;Standard Template Library&#xff0c;标准模板库&#xff09;中的一个核心概念&#xff0c;用于提供一种通用的方式来遍历容器&#xff08;如vector、list、map等&#xff09;中的元素&#xff0c;而无需暴露容…

大小端问题

0. 介绍 大小端计算机存储数据而安排字节的两种顺序。 针对的是字节。 大端与我们平时书写的顺序一致。 1. 大小端的判定 不需要手动判断。 有一个头文件endian.h; 可能会有宏 __BYTE_ORDER __BIG_ENDIAN __LITTLE_ENDIAN通过库来进行判断。 手动判断 根据字节存取的顺序…

【JSON2WEB】07 Amis可视化设计器CRUD增删改查

总算到重点中的核心内容&#xff0c;CRUD也就是增删改查&#xff0c;一个设计科学合理的管理信息系统&#xff0c;95%的就是CRUD&#xff0c;达不到这个比例要重新考虑一下你的数据库设计了。 1 新增页面 Step 1 启动amis-editor Setp 2 新增页面 名称和路径随便命名&#xf…

Dynamo幕墙探究系列(一)

一直想写个系列教程&#xff0c;但是没有那么多时间整理资料&#xff0c;这次呢&#xff0c;先弄个小系列吧&#xff0c;还是和之前差不多的幕墙测试&#xff0c;我们分几节课&#xff0c;一步一步深入研究。 今天先开个小头儿&#xff0c;要弄的&#xff0c;就是下面这么个模型…

对象锁与类锁

不同锁互不影响&#xff0c;共用一个锁&#xff0c;可能会发生阻塞。 1.在修饰静态方法时&#xff0c;锁定的是当前类的 Class 对象&#xff0c;在下面的例子中就是SycTest1.class 2.当修饰非静态方法时&#xff0c;锁定的就是 this 对象&#xff0c;即当前的实例化对象 public…

【Git教程】(四)版本库 —— 存储系统,存储目录,提交对象及其命名、移动与复制~

Git教程 版本库 1️⃣ 一种简单而高效的存储系统2️⃣ 存储目录&#xff1a;Blob 与 Tree3️⃣ 相同数据只存储一次4️⃣ 压缩相似内容5️⃣ 不同文件的散列值相同6️⃣ 提交对象7️⃣ 提交历史中的对象重用8️⃣ 重命名、移动与复制&#x1f33e; 总结 事实上&#xff0c;我们…

keil MDK安装armcc V5编译器

不知道从什么时候开始&#xff0c;Keil MDK默认不支持V5的编译器了&#xff0c;里面默认只有V6的编译器&#xff0c;设置界面跟V5有很大的差异不太熟悉。最可怕的是&#xff0c;之前使用V5编译的工程&#xff0c;换成V6编译器后居然报错...虽然修改一下应该也可以正常编译&…

神经网络基础知识:LeNet的搭建-训练-预测

1.参考视频&#xff1a; 2.1 pytorch官方demo(Lenet)_哔哩哔哩_bilibili 2.总结&#xff1a; &#xff08;1&#xff09;LeNet网络就是 我最开始用来预测mnist数据集的那个网络&#xff0c;简单的2个conv2个maxpool3个linear层 &#xff08;2&#xff09;up主整理的train.py…

SQL面试题(2)

第一题 创建trade_orders表: create table `trade_orders`( `trade_id` varchar(255) NULL DEFAULT NULL, `uers_id` varchar(255), `trade_fee` int(20), `product_id` varchar(255), `time` varchar(255) )ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_…

web自动化笔记九:验证码的处理方式

一、验证码常用的处理方式 ①、说明&#xff1a;Selenium中并没有对验证码处理的方法&#xff0c;在这里我们介绍一下针对验证码的几种常用处理方式 ②、方式&#xff1a; 1&#xff09;、去掉验证码&#xff08;测试环境下采用&#xff09; …