程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

无效的标题签名

发布于2021-10-16 09:34     阅读(492)     评论(0)     点赞(0)     收藏(3)


在这里,我想从.xlsx文件中提取数据,为此我已经添加了 poi jar 并创建了fileInputStream

package demo;


import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;


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

public class DemoExcel {

    public static void main(String[] args) throws Exception{
        File excel = new File("C:\\Users\\Devaditya\\Documents\\Book1.xlsx");
        FileInputStream fis = null;
        fis = new FileInputStream(excel);
        System.out.println(fis.toString());
        HSSFWorkbook wb = new HSSFWorkbook(fis);
        System.out.println(wb.toString());
        HSSFSheet sh = wb.getSheet("Data");
        System.out.println(sh.toString());
    }

}

在这里我收到错误:-

Exception in thread "main" java.io.IOException: Invalid header signature; read 0, expected -2226271756974174256
    at org.apache.poi.poifs.storage.HeaderBlockReader.<init>(HeaderBlockReader.java:88)
    at org.apache.poi.poifs.filesystem.POIFSFileSystem.<init>(POIFSFileSystem.java:83)
    at org.apache.poi.hssf.usermodel.HSSFWorkbook.<init>(HSSFWorkbook.java:210)
    at org.apache.poi.hssf.usermodel.HSSFWorkbook.<init>(HSSFWorkbook.java:191)
    at demo.DemoExcel.main(DemoExcel.java:23)

解决方案


让我们从WorkBook.

HSSFWorkbook

这是旧的二进制专有 Excel 格式,通过扩展名知道.xls

XSSFWorkbook

这是新的 XML Excel 格式,扩展名为.xlsx.

所以,你使用了错误的类。

事实上,最好根本不要使用特定的类,让 POI 计算出你有什么。使用WorkbookFactory

final Workbook workbook = WorkbookFactory.create(excel);

这是:

  1. 编程到interface.
  2. 对读取的工作簿类型的更改具有健壮性,只要 POI 支持它
  3. 更快更高效。POI 可以File在需要时读取零碎的内容,而不必将整个工作簿放入内存中。
  4. 没有内存泄漏的时候你不在,你有close()FileInputStream


所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.javaheidong.com/blog/article/303950/224e3d07da8368be3fca/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

0 0
收藏该文
已收藏

评论内容:(最多支持255个字符)