“Can‘t open workbook - unsupported file type: XML“

java开发,增删改查,涉及到导入excel时,有的excel导入失败提示"Can't open workbook - unsupported file type: XML"。着急赶工期,告诉客户先把excel另存为xls格式,再重新导入。现在有点空余时间,好好研究了下,解决了这个问题。直接上操作啊.

import com.spire.xls.FileFormat;
import org.apache.poi.EmptyFileException;
import org.apache.poi.poifs.filesystem.FileMagic;
//获取文件输入流
InputStream checkis = FileMagic.prepareToCheckMagic(file.getInputStream());
byte[] emptyFileCheck = new byte[1];
checkis.mark(emptyFileCheck.length);
if (checkis.read(emptyFileCheck) < emptyFileCheck.length) {
    throw new EmptyFileException();
} else {
    checkis.reset();
    FileMagic fm = FileMagic.valueOf(checkis);
   //开始判断文件是不是xml格式
    if (FileMagic.XML == fm) {
        com.spire.xls.Workbook workbook=new com.spire.xls.Workbook();
        workbook.loadFromXml(file.getInputStream());
        workbook.saveToFile(fileName, FileFormat.Version2013);
       //接下来开始处理导入excel文件
        ****
    }
}

参考了 poi读取excel报错Your InputStream was neither an OLE2 stream, nor an OOXML stream-CSDN博客

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
et-xmlfile是一个Python库,用于读取和写入大型Excel文件(xlsx格式)而不消耗大量内存。以下是使用et-xmlfile的一些基本示例: 1. 安装et-xmlfile ``` pip install et-xmlfile ``` 2. 读取Excel文件 ```python from openpyxl import load_workbook from openpyxl.utils import get_column_letter from et_xmlfile import parse_xml # 打开Excel文件 workbook = load_workbook(filename='example.xlsx') # 获取第一个工作表 worksheet = workbook.worksheets[0] # 读取单元格 cell = worksheet['A1'] print(cell.value) # 读取整个行 for row in worksheet.iter_rows(min_row=1, max_row=4, min_col=1, max_col=3): for cell in row: print(cell.value) # 读取整个列 for col in worksheet.iter_cols(min_row=1, max_row=4, min_col=1, max_col=3): for cell in col: print(cell.value) ``` 3. 写入Excel文件 ```python from openpyxl import Workbook from openpyxl.utils import get_column_letter from et_xmlfile import parse_xml # 创建一个新的Excel文件 workbook = Workbook() # 获取第一个工作表 worksheet = workbook.active # 写入单元格 worksheet['A1'] = 'Hello' worksheet['B1'] = 'World' # 写入一整行 row = ['Name', 'Age', 'Gender'] worksheet.append(row) # 写入一整列 for i in range(1, 6): col_letter = get_column_letter(i) column = [f'{col_letter}1', f'{col_letter}2', f'{col_letter}3'] worksheet.column_dimensions[col_letter].width = 15 worksheet.append(column) # 保存Excel文件 workbook.save(filename='example.xlsx') ``` 以上是et-xmlfile的基本用法,更多详细信息可以查看其官方文档。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值