使用POI 技术 的SetColumnWidth 精确控制列宽不能成功的解决办法(java)
Posted 吴凯伟
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用POI 技术 的SetColumnWidth 精确控制列宽不能成功的解决办法(java)相关的知识,希望对你有一定的参考价值。
在使用NPOI技术开发自动操作EXCEL软件时遇到不能精确设置列宽的问题。
如
ISheet sheet1 = hssfworkbook.CreateSheet("Sheet1");
sheet1.SetColumnWidth(0, 50 * 256); // 在EXCEL文档中实际列宽为49.29
sheet1.SetColumnWidth(1, 100 * 256); // 在EXCEL文档中实际列宽为99.29
sheet1.SetColumnWidth(2, 150 * 256); // 在EXCEL文档中实际列宽为149.29
到此一般人应该知道问题出在哪了,解决方法如下:
ISheet sheet1 = hssfworkbook.CreateSheet("Sheet1");
sheet1.SetColumnWidth(0, (int)((50 + 0.72) * 256)); // 在EXCEL文档中实际列宽为50
sheet1.SetColumnWidth(1, (int)((100 + 0.72) * 256)); // 在EXCEL文档中实际列宽为100
sheet1.SetColumnWidth(2, (int)((150 + 0.72) * 256)); // 在EXCEL文档中实际列宽为150
既在要设置的实际列宽中加上列宽基数:0.72
以上是关于使用POI 技术 的SetColumnWidth 精确控制列宽不能成功的解决办法(java)的主要内容,如果未能解决你的问题,请参考以下文章
Android GridView——如何以dp单位使用setColumnWidth()设置宽度