poi3.1升级到3.2遇到的问题


项目新功能导出excel需要动态生成下拉列表,而这个需要excel单元格“ 数据有效性”( HSSFDataValidation等)的支持,但3.2之前的poi包不支持,所以为了实现功能而进行了升级。本来业务没涉及到复杂的excel使用,结果发现居然很多api都不向下兼容……

1、所有的setEncoding()方法都舍弃不用(是舍弃,不是过时),改为自动处理(Unicode?)。

所以

cell.setEncoding(HSSFCell.ENCODING_UTF_16);
类似代码必须注释掉。sheet同理。参见 前人讨论

2、HSSFSheet.createRow机制的变化。

    示例代码

package com.zoe.hssftest;

import java.io.BufferedOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class HssfChange {
	public static void main(String[] args) throws IOException {
		HSSFWorkbook wb = new HSSFWorkbook();
		HSSFSheet st = wb.createSheet();
		for(int i =0;i<10;i++) {
			HSSFRow r = st.createRow(0);//可能出bug的点
			HSSFCell c1 = r.createCell((short)i);
			//c1.setEncoding(HSSFCell.ENCODING_UTF_16);//3.1要用到的
			c1.setCellValue("cell"+i);
		}
		BufferedOutputStream bos = 
			new BufferedOutputStream(new FileOutputStream("abc.xls"));  
        wb.write(bos);  
        bos.close();  
	}
	
}
   
使用3.1的包,运行结果如下。

使用3.2的包,运行结果如下。


当然这代码有bug,不过也反映了poi前后两版createRow机制的不同。poi重复创建已存在的row都不会抛出异常,但3.2之前的版本对此的处理是使用已存在的row,新建cell或覆盖已有的cell;而3.2对此的处理是舍弃已存在的row,新建一行。


目前就遇到了这两个问题,api不向下兼容真是害死人。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值