错误描述

java poi读取excel报错Your InputStream was neither an OLE2 stream, nor an OOXML stream

楼主是读取的另存为的excel

定位报错代码

String basePath = "E:\\test\\数据data.xls";
InputStream inp  = new FileInputStream(basePath);
Workbook wb = WorkbookFactory.create(is);

源码定位分析

public static Workbook create(InputStream inp) throws IOException, InvalidFormatException {if (!((InputStream)inp).markSupported()) {inp = new PushbackInputStream((InputStream)inp, 8);}if (POIFSFileSystem.hasPOIFSHeader((InputStream)inp)) {return new HSSFWorkbook((InputStream)inp);} else if (POIXMLDocument.hasOOXMLHeader((InputStream)inp)) {return new XSSFWorkbook(OPCPackage.open((InputStream)inp));} else {throw new IllegalArgumentException("Your InputStream was neither an OLE2 stream, nor an OOXML stream");}}

分析:poi根据path全路径自动解析识别excel格式出错,排除其他文本后缀及格式问题(见错误描述),那就是自动识别xls或者xlsx的问题了

问题解决

InputStream inp = null;
Workbook wb = null;
try {inp = new FileInputStream(basePath);wb = WorkbookFactory.create(inp);
} catch (IOException e) {System.out.println("try catch");inp = new FileInputStream(basePath);if (filePath.contains(".xlsx")) {try {wb = new XSSFWorkbook(OPCPackage.open(inp));} catch (Exception e1) {inp = new FileInputStream(basePath);System.out.println("try catch again1");wb = new HSSFWorkbook(inp);}} else {try {wb = new HSSFWorkbook(inp);} catch (Exception e1) {inp = new FileInputStream(basePath);System.out.println("try catch again1");wb = new XSSFWorkbook(OPCPackage.open(inp));}}} finally {if (null != inp) {try {inp.close();} catch (IOException e) {e.printStackTrace();}}
}

思路:当自动识别出现错误后,在catch里手动指定后缀读取,问题得以解决(InputStream 默认只能读取一次,可以转换成ByteArrayOutputStream或者利用反射实现多次读取【详见下面附录部分】,楼主嫌弃麻烦直接重新new了)

附录

参考自 https://blog.csdn.net/qq_37220419/article/details/104645398

场景描述:我们需要对同一个InputStream对象使用多次。比如,客户端从服务器获取数据 ,利用HttpURLConnection的getInputStream()方法获得Stream对象,需要将InputStream流读取获取相关参数(第一次读取),又想把InputStream流中的数据写进文件缓存到本地(第二次读取)。问题描述:第一次读取InputStream对象后,第二次再读取时可能已经到Stream的结尾了(EOFException)或者Stream已经close掉了,所有获取到的数据为null或者说没有获取到数据。解决方法(一):
因为InputStream对象本身不能复制(InputStream没有实现Cloneable接口),所以先把InputStream转化成ByteArrayOutputStream,后面要使用InputStream对象时,再从ByteArrayOutputStream转化回来就好了,如下代码:
//获取客户端InputStream对象
InputStream input= requset.getInputStream();
//将InputStream对象转换成ByteArrayOutputStream
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len;
while ((len = input.read(buffer)) > -1 ) {  byteArrayOutputStream.write(buffer, 0, len);
}
byteArrayOutputStream.flush();
//将byteArrayOutputStream可转换成多个InputStream对象,达到多次读取InputStream效果
InputStream inputStreamA = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
InputStream inputStreamB = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
//将InputStream转换成字符串
BufferedReader br = new BufferedReader(new InputStreamReader(inputStreamB,"UTF-8"));
String line = null;
StringBuilder sb = new StringBuilder();
while ((line = br.readLine()) != null) {sb.append(line);
}
解决方法二(获取inputStream 的open0方法,反射调用)
@Testpublic void testFileinp() throws IOException, NoSuchMethodException, InvocationTargetException, IllegalAccessException {FileInputStream inputStream=new FileInputStream("E:/test/te.txt");FileOutputStream outputStream=new FileOutputStream("E:/test/te2.txt");FileOutputStream outputStreams=new FileOutputStream("E:/test/te3.txt");int len;byte [] by=new byte[8192];while ((len=inputStream.read(by))!=-1){outputStream.write(by,0,len);}if(inputStream.read()==-1){Class in=inputStream.getClass();Method openo= in.getDeclaredMethod("open0", String.class);openo.setAccessible(true);openo.invoke(inputStream,"E:/test/te.txt");}while ((len=inputStream.read(by))!=-1){outputStreams.write(by,0,len);}outputStream.close();}

附上具体操作demo实例 :excel(xls或xlsx)便捷copy及poi操作demo.rar https://download.csdn.net/download/qq_25073261/85111496

java poi读取excel报错Your InputStream was neither an OLE2 stream, nor an OOXML stream相关推荐

  1. Poi读取Excle报错 java.util.zip.ZipException: invalid stored block lengths

    一:Poi读取Excle报错  java.util.zip.ZipException: invalid stored block lengths 系统中需要导出excle签收单,excle模板是预设好 ...

  2. 使用poi导出excel报错-打开文件报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”

    使用poi导出excel报错-打开文件报"Excel 已完成文件级验证和修复.此工作簿的某些部分可能已被修复或丢弃" 1.原本正常使用的Excel导出突然下载文件报错 2.定位时发 ...

  3. java poi 读取excel 图片_Poi读取excel插图的方法和操作步骤

    我们在使用Excel制作表格的时候,有时会使用"Poi读取excel插图",但是很多初学者都不懂也不会制作.下面,我就给大家讲一下"Poi读取excel插图"的 ...

  4. java poi读取excel文件(xlsx)

    读取excel文件的方法有许多种,这篇文章主要描述通过poi读取excel文件. 先maven导入jar包 <dependency><groupId>org.apache.po ...

  5. 使用Java POI读取excel文档

    Java使用POI读取excel文档教程 一:Poi的介绍 1.简介 1.由apache公司提供 2.Java编写的免费开源的跨平台的Java API 3.提供API给Java程序对Microsoft ...

  6. excel导出java.lang.ArrayIndexOutOfBoundsException: 0 POI导出excel报错数组下标越界0

    好久没写博客了,最近是有点懒了... 最近项目遇到个问题,用poi导出excel,本地和测试服务器都没问题,线上所有的导出都不能用,排查过JKD版本和配置文件都没问题,百思不得其解,最终问了朋友考虑到 ...

  7. java POI 读取Excel文件 将图片、表格生成到PPT

    临时有个需求,要求通过读取EXCEL文件,然后通过文件名称去给定的文件夹内查找图片,并将图片写入PPT中,详情以表格的形式写到图片右侧,每张图片一页PPT.效果如图所示: 用到的jar包如下(mave ...

  8. java poi 读取excel 编码_Java使用POI 读取和写入Excel指南

    做项目时经常有通过程序读取Excel数据,或是创建新的Excel并写入数据的需求:网上很多经验教程里使用的POI版本都比较老了,一些API在新版里已经废弃,这里基于最新的Apache POI 4.0. ...

  9. java poi读取excel,2147483647问题

    读取excel文件的时候,某些单元格是数字,但是可能超过10位,例如电话号码,读取之后会变为2147483647,改变下读取的长度就好了.例如value +=  (long) cell.getNume ...

最新文章

  1. 布局类型java_java – 我们可以为所有屏幕大小制作一种布局类型
  2. linux虚拟机上不了王,虚拟机上安装Linux时出现的问题及解决方法
  3. redis 模糊删除实现
  4. emqx—mqtt消息服务器
  5. JDBC连接池JDBCTemplate课堂笔记
  6. nuxt2中使用less
  7. Flyweight Design Pattern 共享元设计模式
  8. 实现两个pawn的切换
  9. 软件质量管理之困境与对策思考
  10. 5美元的互联网硬件主板
  11. 【CF Contest-1251 E2】Voting (Hard Version)【贪心】
  12. Windows小技巧 – Win+R提高Windows使用效率
  13. php读取excel文件_在PHP中读取Excel文件
  14. ClientKey实现登录QQ空间,并设置背景音乐
  15. java中最多小数位_在Java中最多2位小数?
  16. Scientific Linux 6(x86_64) 之旅
  17. Python爬取10529条《三十而已》热评,看看大家都说了些啥!
  18. 如何安装tushare
  19. python-查找字符串
  20. 关于数据结构的内存分配问题

热门文章

  1. 荣耀30青春版鸿蒙,良心:荣耀30青春版保留3.5mm耳机孔
  2. LPCSTR CONST 指针
  3. Bert结构代码阅读笔记
  4. MySQL8中的11个窗口函数
  5. appserv安装好后localhost无法访问:简单的处理方法
  6. 幽默的心理本质是什么?
  7. GL-日记账接口导入
  8. 莱昂纳德:今年的决赛没有亚军,勇士比我们更配得上欢呼声
  9. 你是否需要加强你的钝感力?
  10. Random库中的8个函数