[转]java用POI设置Excel的列宽

2024-08-30 08:18
文章标签 java excel 设置 poi

本文主要是介绍[转]java用POI设置Excel的列宽,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

ExcelWriter writer = ExcelUtil.getWriter();// 设置字段名
writer.addHeaderAlias("sequenceNumber", "序号");int[] width = {5,35,19,13,11,11,11,13,17,80};// Excel表格宽度*256
for(int i=0; i<width.length;i++) {writer.getSheet().setColumnWidth(i,width[i]*256);
}


 

 

 

 

需求:将某个excel中的某一列列宽设置为35(该数值是Excel中显示的列宽值)。
poi中设置列宽的方法为:

HSSFSheet.setColumnWidth(int columnIndex, int width);

第一个参数好理解–列序号,关键是第二个参数宽度的值,应该设置为多少呢?
我做了以下尝试,发现均不好使

sheet.setColumnWidth(0, 35);            //a
sheet.setColumnWidth(0, (int)35.7*35);  //b
sheet.setColumnWidth(0, 256*35);        //c

查了以下,上面c这种写法比较接近想要的结果,因为setColumnWidth这个方法宽度的单位是字符数的256分之一,但是我想要点开Excel查看那一列的宽度时就显示35,而不是34.29。如何比较精确地设置列宽呢?我想到了拟合方程这四个字。
所谓拟合是指已知某函数的若干离散函数值{f1,f2,…,fn},通过调整该函数中若干待定系数f(λ1, λ2,…,λn),使得该函数与已知点集的差别(最小二乘意义)最小。(来自百度百科)
说白了就是给你几个离散点,让你找规律,求出这些点满足的函数表达式y=f(x)。有人要说了,这玩意上学的时候都没学会,现在更不会求了。没关系,我们可以借助软件的力量。最简单的软件就是Excel了。
说干就干。先尝试以下设置

sheet.setColumnWidth(0, 9100);
sheet.setColumnWidth(0, 9150);
sheet.setColumnWidth(0, 9200);
sheet.setColumnWidth(0, 9250);
sheet.setColumnWidth(0, 9300);
sheet.setColumnWidth(0, 9350);

将生成的Excel的对应列的实际宽度记录下来:
[34.86,35,35.29,35.43,35.57,35.86]
以实际宽度为自变量x,你给的值为函数值y,得到一系列离散点:(34.86,9100)(35,9150)(35.29,9200)(35.43,9250)(35.57,9300)(35.86,9350)
新建一个工作表,将数据输入

xy
34.869100
359150
35.299200
35.439250
35.579300
35.869350

选中这些数据,点插入->图表->散点图,数据有了之后,再添加趋势线,选线性,并显示公式,结果如图
这里写图片描述
好我们得到了y与x的关系,接下来代码里就该这样设置了:

sheet.setColumnWidth(0, 252*width+323);//width=35

但是这个公式并不十分准确,比如当width=9时,生成的Excel实际宽度却是9.43,怎么办?多取一些点再进行拟合。
于是有了下面的结果:
这里写图片描述
最后我们的表达式为:y=255.86x+184.27
代码里这样设置

sheet.setColumnWidth(0, 256*width+184);

这次就比较精确了。

 

这篇关于[转]java用POI设置Excel的列宽的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志