java用POI设置Excel的列宽 灰太狼 2022-05-31 00:18 2169阅读 0赞 **java用POI设置Excel的列宽** **今天看博客,觉得这篇挺好,挺有意思的。转载一下。实践是真理。** 需求:将某个excel中的某一列列宽设置为35(该数值是Excel中显示的列宽值)。 poi中设置列宽的方法为: HSSFSheet.setColumnWidth(int columnIndex, int width); 1 第一个参数好理解–列序号,关键是第二个参数宽度的值,应该设置为多少呢? 我做了以下尝试,发现均不好使 sheet.setColumnWidth(0, 35); //a sheet.setColumnWidth(0, (int)35.7*35); //b sheet.setColumnWidth(0, 256*35); //c 1 2 3 查了以下,上面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); 1 2 3 4 5 6 将生成的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) 新建一个工作表,将数据输入 <table style="width:780px; color:rgb(69,69,69); font-size:16px"> <thead> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221)"> <th style="color:rgb(79,79,79); padding-right:8px; padding-left:8px; text-align:left; background-color:rgb(239,243,245)"> x</th> <th style="color:rgb(79,79,79); padding-right:8px; padding-left:8px; text-align:left; background-color:rgb(239,243,245)"> y</th> </tr> </thead> <tbody style="border:0px"> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">34.86</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9100</td> </tr> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221); background-color:rgb(247,247,247)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">35</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9150</td> </tr> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">35.29</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9200</td> </tr> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221); background-color:rgb(247,247,247)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">35.43</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9250</td> </tr> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">35.57</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9300</td> </tr> <tr style="border-width:1px 0px 0px; border-right-style:initial; border-bottom-style:initial; border-left-style:initial; border-right-color:initial; border-bottom-color:initial; border-left-color:initial; border-top-style:solid; border-top-color:rgb(221,221,221); background-color:rgb(247,247,247)"> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">35.86</td> <td style="color:rgb(79,79,79); padding-right:8px; padding-left:8px">9350</td> </tr> </tbody> </table> 选中这些数据,点`插入`\->`图表`\->`散点图`,数据有了之后,再添加`趋势线`,选`线性`,并`显示公式`,结果如图 ![这里写图片描述][20160524161745613] 好我们得到了y与x的关系,接下来代码里就该这样设置了: sheet.setColumnWidth(0, 252*width+323);//width=35 1 但是这个公式并不十分准确,比如当width=9时,生成的Excel实际宽度却是9.43,怎么办?多取一些点再进行拟合。 于是有了下面的结果: ![这里写图片描述][20160524162242804] 最后我们的表达式为:y=255.86x+184.27 代码里这样设置 sheet.setColumnWidth(0, 256*width+184); 1 这次就比较精确了。 [20160524161745613]: /images/20220531/27aa231c8b93446cbe2da222a4d69b31.png [20160524162242804]: /images/20220531/9f1fb12a61234df7985c0113afc51b29.png
还没有评论,来说两句吧...