使用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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM