POI对Excel单元格的格式的设置参数
最近在做导出Excel的功能封装,遇到了几个问题:
- 单元格宽度问题
- 数据不是数字格式问题
- 格式化了之后显示的不是数字而是######的问题(其实是因为单元格宽度不够导致的无法显示格式化之后的内容)
下面先说说解决方法:
1、单元格宽度问题
这个问题有两个解决办法,一个是
sheet.autoSizeColumn(1);
sheet.autoSizeColumn(1, true);
这种是自适应,第一参数是列号,从0开始,第二参数是是否考虑合并单元格。
还有一种是固定的多宽,这个宽度值就交给自己去测试了:
sheet.setColumnWidth(1, 5000)
这个第二个参数是宽度,具体上面说了自己测试。5000就很宽了,看放什么了。
2、数据不是数字格式问题
这个看api的感觉应该是设置这么个参数,cell.setCellType(Cell.CELL_TYPE_NUMERIC);
但是实际上这个参数设置了不起作用,后来发现自己放的值是String类型,所以不行,后来改为了Double.valueOf(str)方法,发现还是不行,换成Double.parseDouble(str)就行了,原来前面的方法返回的是Double,后面的是double,封装类型也不行。。。
后来就统一把所有的参数设置为Object类型了,这样好转。
3、格式化后显示###
这里是因为宽度不够啦&#