【EasyExcel】根据单元格内容自动调整列宽

1.自定义Excel列宽样式策略类

import com.alibaba.excel.enums.CellDataTypeEnum;
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.commons.collections.CollectionUtils;
import org.apache.poi.ss.usermodel.Cell;import java.util.HashMap;
import java.util.List;
import java.util.Map;
/*** 自定义Excel列宽样式策略类,用于根据单元格内容自动调整列宽。* 继承自 AbstractColumnWidthStyleStrategy 以提供列宽调整功能。*/
public class ExcelWidthStyleStrategy extends AbstractColumnWidthStyleStrategy {// 定义单元格最大列宽,避免列宽过大private static final int MAX_COLUMN_WIDTH = 30;// 缓存每个sheet中每列的最大列宽private final Map<Integer, Map<Integer, Integer>> columnWidthCache = new HashMap<>(8);/*** 设置列宽的方法,根据单元格内容的长度动态调整列宽。** @param writeSheetHolder 写入Sheet的持有者* @param cellDataList 当前列的单元格数据列表* @param cell 当前单元格* @param head 表头* @param relativeRowIndex 当前行的相对索引* @param isHead 是否为表头*/@Overrideprotected void setColumnWidth(WriteSheetHolder writeSheetHolder,List<WriteCellData<?>> cellDataList,Cell cell,Head head,Integer relativeRowIndex,Boolean isHead) {// 如果是表头或者单元格数据列表不为空,则需要设置列宽boolean needSetWidth = isHead || !CollectionUtils.isEmpty(cellDataList);if (needSetWidth) {// 获取当前sheet的列宽缓存Map<Integer, Integer> columnWidthMap =columnWidthCache.computeIfAbsent(writeSheetHolder.getSheetNo(), k -> new HashMap<>(16));// 计算当前单元格的数据长度Integer columnWidth = computeCellDataLength(cellDataList, cell, isHead);if (columnWidth >= 0) {// 确保列宽不会超过最大值columnWidth = Math.min(columnWidth, MAX_COLUMN_WIDTH);// 获取当前列的最大列宽Integer maxColumnWidth = columnWidthMap.get(cell.getColumnIndex());// 如果当前列宽大于缓存中的最大列宽,则更新缓存并设置列宽if (maxColumnWidth == null || columnWidth > maxColumnWidth) {columnWidthMap.put(cell.getColumnIndex(), columnWidth);// 设置列宽,乘以512是因为Excel中列宽单位与字符长度有关writeSheetHolder.getSheet().setColumnWidth(cell.getColumnIndex(), columnWidth * 512);}}}}/*** 计算单元格内容的字节长度** @param cellDataList 当前列的单元格数据列表* @param cell 当前单元格* @param isHead 是否为表头* @return 单元格内容的字节长度*/private Integer computeCellDataLength(List<WriteCellData<?>> cellDataList, Cell cell, Boolean isHead) {if (isHead) {// 表头直接计算字符串的字节长度return cell.getStringCellValue().getBytes().length;} else {if (cellDataList == null || cellDataList.isEmpty()) {return -1; // 如果数据列表为空,则返回-1}WriteCellData<?> cellData = cellDataList.get(0);CellDataTypeEnum type = cellData.getType();if (type == null) {return -1; // 如果类型未知,则返回-1} else {switch (type) {case STRING:return cellData.getStringValue().getBytes().length;case BOOLEAN:return cellData.getBooleanValue().toString().getBytes().length;case NUMBER:return cellData.getNumberValue().toString().getBytes().length;default:return -1; // 对于其他类型,返回-1}}}}
}

2.使用策略

        excelWriter.write(ExcelData, EasyExcel.writerSheet(sheetName).head(Product.class).registerWriteHandler(new ExcelWidthStyleStrategy()).build());

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

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

相关文章

NodeJS校园点餐系统-计算机毕业设计源码56979

摘 要 近年来&#xff0c;随着移动互联网的迅猛发展&#xff0c;微信小程序作为一种轻量级应用形式逐渐受到人们的关注和喜爱。在此背景下&#xff0c;各行各业开始向微信小程序上线他们的服务&#xff0c;其中包括餐饮行业&#xff0c;在校园内&#xff0c;学生、教职工和访客…

通用代码生成器模板体系,域对象,枚举和动词算子

通用代码生成器模板体系&#xff0c;域对象&#xff0c;枚举和动词算子 通用代码生成器或者叫动词算子式通用目的代码生成器是一组使用Java编写的通用代码生成器。它们的原理基于动词算子和域对象的笛卡尔积。它们没有使用FreeMarker和或者Velocity等现成的文件式模板引擎。而…

OpenResty程序如何连接开启了TLS的Redis?

目录 OpenResty 项目如何连接开启了 TLS 的 Redis Kong 插件如何连接开启了 TLS 的 Redis OpenResty 是一个基于 Nginx 和 Lua 的 Web 应用框架&#xff0c;允许开发者通过 Lua 脚本对 Nginx 的配置和行为进行扩展。当 OpenResty 需要连接到一个开启了 TLS 的 Redis 服务器时…

传统的springboot项目中,如何进行添加自定义静态资源访问路径实现对静态资源的访问?

如何配置可以实现在浏览器中配置路径实现对resource资源路径下的index.html个性化定制访问路径 要在Spring Boot项目中配置使特定前缀访问静态资源&#xff0c;可以在application.yml文件中配置路径映射。以下是一个示例配置&#xff1a; 打开你的application.yml文件&#xf…

Kylin的优缺点

Kylin&#xff08;Apache Kylin&#xff09;是一个开源的分布式分析数据仓库&#xff0c;专为处理大规模数据集和提供快速的多维分析&#xff08;OLAP&#xff09;能力而设计。以下是Kylin的主要优点和缺点&#xff1a; 优点 高性能&#xff1a; 快速查询&#xff1a;Kylin通过…

Vue3响应系统的作用与实现

副作用函数的执行会直接或间接影响其他函数的执行。一个副作用函数中读取了某个对象的属性&#xff0c;当该属性的值发生改变后&#xff0c;副作用函数自动重新执行&#xff0c;这个对象就是响应式数据。 1 响应式系统的实现 拦截对象的读取和设置操作。当读取某个属性值时&a…

死灰复燃的 LockBit, “现身说法”计算机安全的重要性

LockBit 死灰复燃 2024年2月&#xff0c;一场全球性的名为 “Cronos 行动” 的执法行动夺取了对 LockBit 勒索组织基础设施的控制权并扰乱了其运营。 但是&#xff0c;就像希腊神话中的九头蛇一样&#xff0c;砍掉一个 LockBit 的头并不重要——它可以迅速再生成多个新的头。…

南京邮电大学运筹学课程实验报告3 整数规划问题求解 指导

一、题目描述 实验三 整数规划问题求解    实验属性&#xff1a; 设计型    实验目的 1&#xff0e;理解图的整数规划问题概念&#xff1b; 2&#xff0e;掌握运筹学软件的使用方法&#xff1b; 3. 掌握整数规划问题求解原理和方法。 实…

傅里叶变换DFT\FFT

文章目录 直流分量&#xff08;频率为0&#xff09;傅立叶原理离散频率栅栏效应原理方案&#xff1a;提高采样间隔&#xff08;频率分辨力&#xff09; 直流分量&#xff08;频率为0&#xff09; 指信号中的直流成分&#xff0c;信号的直流分量就是信号的平均值&#xff0c;它…

MES系统助力塑料制品行业数字化转型

注塑MES系统助力工厂生产力提升具体体现在&#xff1a;覆盖生产全流程&#xff1b;数据自动收集、科学规划排产&#xff1b;优化配送模型、平衡物流运转&#xff1b;严格把控品质、异常自动分析&#xff1b;实时监控设备&#xff0c;保证正常运转&#xff1b;产品快速追溯&…

c#获取本机的MAC地址(附源码)

在前一次的项目中&#xff0c;突然用到了这个获取本机的MAC地址&#xff0c;然后就研究了一下&#xff0c;记录下来&#xff0c;防止以后再用到&#xff0c; 使用winfrom做的&#xff0c;界面一个button&#xff0c;一个textBox,点了button以后给textBox赋值显示mac地址 附上源…

C#基于事件的异步模式实现实例

1、异步操作类 using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Runtime.Remoting.Messaging; using System.Text; using System.Threading; using System.Threading.Tasks; using static System.Windows.For…

Linux下vim工具应用

1.简介 Vim&#xff08;Vi IMproved&#xff09;是一种高度可配置的文本编辑器&#xff0c;用于有效地创建和更改任何类型的文本。它是从vi发展而来&#xff0c;vi是Unix和类Unix系统上最初的文本编辑器之一。Vim被设计为程序员和文本编辑的爱好者使用&#xff0c;它以其强大的…

广度优先(BFS)

先看一道简单的题&#xff0c;迷宫问题&#xff1a; 洛谷P1746 离开中山路&#xff1a;P1746 离开中山路 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) #include<iostream> #include<cstring> #include<queue> #include <utility> #define N 1002 …

综合监管云平台 DownFile 任意文件读取漏洞复现

0x01 产品简介 综合监管云平台是一种集成了多种先进技术的信息化平台&#xff0c;旨在通过数据采集、分析、预警和应急处理等功能&#xff0c;实现对各类监管对象的全面、高效、精准管理&#xff0c;综合监管云平台利用“互联网物联网”模式&#xff0c;结合云计算、大数据、边…

春招冲刺百题计划|队列

Java基础复习 Java数组的声明与初始化Java ArrayListJava HashMapJava String 类Java LinkedListJava Deque继承LinkedListJava SetJava 队列 第一题&#xff1a;387. 字符串中的第一个唯一字符 class Solution {public int firstUniqChar(String s) {//最简单的方法就是暴力…

p14数组(2)

数组作为函数的参数 冒泡排序 两两比较 void bubble_sort(int arr[],int sz) {int i0;for(i0;i<sz-1;i){//每一趟冒泡排序int j0;for(j0;j<sz-1-i;j){if(arr[j]>arr[j1]){int tmparr[j];arr[j]arr[j1];arr[j1]tmp;}}} } int main(){int arr[]{9,8,7,6,5,4,3,2,1,0}…

关于woocommerce product data tabs, 特别是additional information

woocommerce product data tabs&#xff0c; 也就是默认的这三个&#xff1a; description additional information reviews 包括如何删除&#xff0c;重命名&#xff0c;改显示顺序等等&#xff0c;参考官方文档&#xff1a; https://woocommerce.com/document/editing-p…

《从零到惊艳:快速唱好一首歌的魔法指南》

对于零基础学唱歌的朋友来说&#xff0c;想要快速学会唱好一首歌并非遥不可及。 第一步&#xff0c;精心选歌。如同选择一把适合自己的宝剑&#xff0c;歌曲的选择至关重要。要挑选一首旋律优美、节奏适中、音域符合自身条件且歌词易于理解和记忆的歌曲。比如一些节奏较为缓慢、…

C# CvDnn部署CoupledTPS实现旋转图像矫正

C# CvDnn部署CoupledTPS实现旋转图像矫正 目录 说明 效果 模型信息 项目 代码 下载 说明 TPAMI2024 - Semi-Supervised Coupled Thin-Plate Spline Model for Rotation Correction and Beyond github地址&#xff1a;https://github.com/nie-lang/CoupledTPS 代码实现…