java poi读取excel报错Your InputStream was neither an OLE2 stream, nor an OOXML stream
错误描述
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相关推荐
- Poi读取Excle报错 java.util.zip.ZipException: invalid stored block lengths
一:Poi读取Excle报错 java.util.zip.ZipException: invalid stored block lengths 系统中需要导出excle签收单,excle模板是预设好 ...
- 使用poi导出excel报错-打开文件报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”
使用poi导出excel报错-打开文件报"Excel 已完成文件级验证和修复.此工作簿的某些部分可能已被修复或丢弃" 1.原本正常使用的Excel导出突然下载文件报错 2.定位时发 ...
- java poi 读取excel 图片_Poi读取excel插图的方法和操作步骤
我们在使用Excel制作表格的时候,有时会使用"Poi读取excel插图",但是很多初学者都不懂也不会制作.下面,我就给大家讲一下"Poi读取excel插图"的 ...
- java poi读取excel文件(xlsx)
读取excel文件的方法有许多种,这篇文章主要描述通过poi读取excel文件. 先maven导入jar包 <dependency><groupId>org.apache.po ...
- 使用Java POI读取excel文档
Java使用POI读取excel文档教程 一:Poi的介绍 1.简介 1.由apache公司提供 2.Java编写的免费开源的跨平台的Java API 3.提供API给Java程序对Microsoft ...
- excel导出java.lang.ArrayIndexOutOfBoundsException: 0 POI导出excel报错数组下标越界0
好久没写博客了,最近是有点懒了... 最近项目遇到个问题,用poi导出excel,本地和测试服务器都没问题,线上所有的导出都不能用,排查过JKD版本和配置文件都没问题,百思不得其解,最终问了朋友考虑到 ...
- java POI 读取Excel文件 将图片、表格生成到PPT
临时有个需求,要求通过读取EXCEL文件,然后通过文件名称去给定的文件夹内查找图片,并将图片写入PPT中,详情以表格的形式写到图片右侧,每张图片一页PPT.效果如图所示: 用到的jar包如下(mave ...
- java poi 读取excel 编码_Java使用POI 读取和写入Excel指南
做项目时经常有通过程序读取Excel数据,或是创建新的Excel并写入数据的需求:网上很多经验教程里使用的POI版本都比较老了,一些API在新版里已经废弃,这里基于最新的Apache POI 4.0. ...
- java poi读取excel,2147483647问题
读取excel文件的时候,某些单元格是数字,但是可能超过10位,例如电话号码,读取之后会变为2147483647,改变下读取的长度就好了.例如value += (long) cell.getNume ...
最新文章
- 布局类型java_java – 我们可以为所有屏幕大小制作一种布局类型
- linux虚拟机上不了王,虚拟机上安装Linux时出现的问题及解决方法
- redis 模糊删除实现
- emqx—mqtt消息服务器
- JDBC连接池JDBCTemplate课堂笔记
- nuxt2中使用less
- Flyweight Design Pattern 共享元设计模式
- 实现两个pawn的切换
- 软件质量管理之困境与对策思考
- 5美元的互联网硬件主板
- 【CF Contest-1251 E2】Voting (Hard Version)【贪心】
- Windows小技巧 – Win+R提高Windows使用效率
- php读取excel文件_在PHP中读取Excel文件
- ClientKey实现登录QQ空间,并设置背景音乐
- java中最多小数位_在Java中最多2位小数?
- Scientific Linux 6(x86_64) 之旅
- Python爬取10529条《三十而已》热评,看看大家都说了些啥!
- 如何安装tushare
- python-查找字符串
- 关于数据结构的内存分配问题