解决jxl导出excel异常:java.lang.ArrayIndexOutOfBoundsException

jxl ArrayIndexOutOfBoundsException异常

ArrayIndexOutOfBoundsException

异常的Log如下:

java.lang.ArrayIndexOutOfBoundsException: length=5; index=5
    at jxl.biff.IndexMapping.getNewIndex(IndexMapping.java:68)
   at jxl.biff.FormattingRecords.rationalize(FormattingRecords.java:388)
    at jxl.write.biff.WritableWorkbookImpl.rationalize(WritableWorkbookImpl.java:1023)
    at jxl.write.biff.WritableWorkbookImpl.write(WritableWorkbookImpl.java:701)

该异常发生在导出excel文件:writableWorkbook.write();的时候,jxl.biff.IndexMapping 执行 getNewIndex(int oldIndex) 时候越界

可能解决方案

查询了网上一些资料:

  • 可能解决方案1,如下:链接
    jxl.biff下的FormattingRecords.java这个类中出的问题,它定义了一个变量private static final int maxFormatRecordsIndex = 0x1b9;即最大纪录格式数目为441,因此每当拷贝的单元格超过这个变量值的时候就会报错,解决的方法就是把这个0x1b9换成一个大点的值

  • 可能解决方案2,如下:链接
    jxl导出程序是不能用静态的,把程序静态都去掉

  • 可能解决方案3:如下:链接
    使用WritableCellFormat时都new一个新的对象就没问题了

总结

总的来说,该问题很大可能是因为单元格格式Format的问题,以上的解决方案1,修改源码是不太适合的,而且有的情况下也是不允许修改源码的,而方案2和方案3总的来说应该是以下解决方法:

首先明确自己的代码是否是该情况:

* 一般excel的很多单元格的格式都是一样的*,例如表头的单元格、数据的单元格等,因此我们很容易想到了复用,用全局变量 headFormat、contentFormat保存我们的单元格格式(甚至保存为static变量,也就是解决方案2出现的static),然后出现了以下的代码:

private WritableCellFormat contentFormat = null;

...

Label label = new Label(col, row, content, getContentFormat());

...

public WritableCellFormat getContentFormat() {
    if (contentFormat == null) {
        ....
    }
    return contentFormat;
}

解决该Exception的方法:使用WritableCellFormat时都new一个新的对象便可以解决该问题,以上getContentFormat()代码改为:

public WritableCellFormat getContentFormat() {
    // 返回一个新的WritableCellFormat对象
    WritableCellFormat contentFormat = new WritableFont(...);
    ...
    return contentFormat;
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值