[转]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);

这次就比较精确了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值