解决jxl导出excel异常:java.lang.ArrayIndexOutOfBoundsException
来源:互联网 发布:java单元测试testng 编辑:程序博客网 时间:2024/04/29 03:46
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;}
- 解决jxl导出excel异常:java.lang.ArrayIndexOutOfBoundsException
- jxl导出excel异常:java.lang.ArrayIndexOutOfBoundsException: 31
- JXL导出Excel抛java.lang.ArrayIndexOutOfBoundsException: 5
- jxl java.lang.ArrayIndexOutOfBoundsException: 164 异常解决方法
- jxl导出EXCEL的java.lang.IllegalStateException异常
- 使用JXL生成Excel时发生java.lang.ArrayIndexOutOfBoundsException错误
- 使用JXL生成Excel时发生java.lang.ArrayIndexOutOfBoundsException错误
- 使用JXL生成Excel时发生java.lang.ArrayIndexOutOfBoundsException错误
- java.lang.ArrayIndexOutOfBoundsException异常分析及解决
- java.lang.ArrayIndexOutOfBoundsException异常分析及解决
- java.lang.ArrayIndexOutOfBoundsException异常分析及解决
- java.lang.ArrayIndexOutOfBoundsException异常分析及解决
- jxl 错误 java.lang.ArrayIndexOutOfBoundsException: 441
- jxl操作java.lang.ArrayIndexOutOfBoundsException: 441 错误
- jxl读取excel,Java heap space,ArrayIndexOutOfBoundsException,java.lang.System.arraycopy(Native Method),
- java.lang.ArrayIndexOutOfBoundsException异常问题
- [经验小结]jxl写excel时产生“java.lang.ArrayIndexOutOfBoundsException: 5”问题的解决办法
- Linux环境下 使用JXL生成Excel时发生java.lang.ArrayIndexOutOfBoundsException
- EasyUi常用组件(三)Panel 控制面板
- 问题
- 差分。。部分更新 android apk
- Java总结篇系列:Java泛型(转)
- # html+css基础学习笔记-选择器介绍
- 解决jxl导出excel异常:java.lang.ArrayIndexOutOfBoundsException
- 超强、超详细Redis数据库入门教程
- 时间戳格式化-java
- Redis和Memcache的区别分析
- 提交spark程序
- MY PIE
- Android URL scheme
- jqgrid设置取消选择
- Android中 PopupWindow 与 ListView 结合使用