poi处理excel文件出现单元格样式太多的问题

2023-10-09 07:50

本文主要是介绍poi处理excel文件出现单元格样式太多的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:项目运行一段时间后,同事反馈说excel的单元格样式没有了,我心想怎么可能呢,结果把线上的文件拿出来一打开,提示恢复工作簿内容。如图:

马虎造成poi处理excel文件出现单元格样式太多的问题

文件打开提示

接着点击“是”进入

马虎造成poi处理excel文件出现单元格样式太多的问题

单元格样式丢失

样式全部丢失了。什么情况,马上本地写了测试的执行看看,发现当行数小于5700行(这是本人测试的,可能别人是别的行数)时,是正常的,但是一超过这个行数立马样式消失。网上百度了一下,说是我创建的style太多了,一看代码,的确是,因为我style都是在循环里面创建的。应该拿到循环外面统一创建。

马虎造成poi处理excel文件出现单元格样式太多的问题

创建样式

从我截取的代码中可以看得出,我这里肯定处理的不对,造成频繁的创建style,修改办法是创建HashMap进行缓存,用到的时候在这里拿取。

马虎造成poi处理excel文件出现单元格样式太多的问题

将必用的样式缓存在map中

马虎造成poi处理excel文件出现单元格样式太多的问题

用时通过key来获取

修改成这样,此问题解决了。如图:

马虎造成poi处理excel文件出现单元格样式太多的问题

样式不消失了

多循环些,看看数据量1w行时

马虎造成poi处理excel文件出现单元格样式太多的问题

1w行

仍然没有出现问题。

总结:

  1. 因为excel不能支持太多的样式,而且项目中也没有很多样式,造成样式多,完全是因为在for循环中,创建了一些重复的样式造成的。
  2. 还有这样频繁的创建样式也造成了性能问题。

这篇关于poi处理excel文件出现单元格样式太多的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/171394

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决