解决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;
}

你可能感兴趣的:(Java)