poi的一个让人失望的bug

      用poi读取ws的ppt文件时,会抛出Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8的异常。(使用版本poi-3.0.2)。

      解决办法是,打开项目的properties->java build path->order and export,发现poi放到了最后,把poi的包上移。问题解决!

     上面的问题解决之后,再读取ws的word文件是,就会抛出java.lang.StringIndexOutOfBoundsException: String index out of range: -86的异常。解决办法是,打开项目的properties->java build path->order and export,把poi的包下移到最后。问题解决!

     如果用的是poi-3.1的话,会抛出Exception in thread "main" java.lang.NoSuchMethodError: org.apache.poi.poifs.filesystem.POIFSFileSystem.getRoot()Lorg/apache/poi/poifs/filesystem/DirectoryNode;的异常,解决方法是把org/apache/poi/poifs/filesystem的class文件提取出来,放在bin里面,之后还是抛出java.lang.StringIndexOutOfBoundsException和java.lang.ArrayIndexOutOfBoundsException的异常。

     综上,要在同一个项目用poi同时读取word和ppt文件,会出现异常。除非你的work文件只有半页纸不到的内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
POI是Apache软件基金会推出的一款用于操作Microsoft Office格式文件的Java库。它可以帮助我们读取、创建和修改Excel文件。 在POI中,Sheet页可以理解为Excel文件中的工作表,而一个Sheet页可以包含多个表头。表头通常用于标识和描述该Sheet页中数据的每一列。 在创建一个带有多个表头的Sheet页时,首先需要创建一个Sheet对象,然后通过调用该对象的createRow方法创建行对象,最后在行对象中使用createCell方法创建单元格对象并设置单元格的值。 将多个表头写入到Sheet页中的步骤如下: 1. 创建Sheet对象:使用Workbook对象的createSheet方法创建一个Sheet对象,可指定Sheet页的名称和索引。 2. 创建行对象:使用Sheet对象的createRow方法创建一个行对象,表示Sheet页中的一行数据。 3. 创建单元格对象:使用行对象的createCell方法创建多个单元格对象。 4. 设置表头值:使用单元格对象的setCellValue方法将表头的值设置到对应的单元格中。 5. 设置表头样式:使用POI提供的样式类和字体类,可以设置表头的样式,包括字体、颜色、边框等。 6. 重复步骤2-5,直到将所有表头的值设置完成。 7. 将Sheet页写入到Excel文件中:使用Workbook对象的write方法将Sheet页写入到Excel文件中。 总的来说,POI可以很方便地操作Excel文件,在创建Sheet页时,我们可以根据需求来设置多个表头,通过调用POI提供的方法将表头值写入到对应的单元格中。这样就可以实现一个Sheet页中包含多个表头的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值