java解析excel2003和excel2007:The supplied data appears to be in the office 2007+XML Polonly supports OLE2 office documents

来源:http://www.cnblogs.com/my-sun/archive/2016/10/19/5976293.html
-Advertisement-
Play Games

上傳excel解析存到資料庫時報: org.apache.poi.poifs.filesystem.OfficeXmlFileException: The supplied data appears to be in the Office 2007+ XML. You are calling the ...


上傳excel解析存到資料庫時報:

org.apache.poi.poifs.filesystem.OfficeXmlFileException:

The supplied data appears to be in the Office 2007+ XML. You are calling the part of POI that deals with OLE2 Office Documents.

You need to call a different part of POI to process this data (eg XSSF instead of HSSF)

該錯誤意思是說,文件中的數據是用Office2007+XML保存的,而現在卻調用OLE2 Office文檔處理,應該使用POI不同的部分來處理這些數據,

比如使用XSSF來代替HSSF。

斷點跟蹤到:new HSSFWorkbook(file.getInputStream)出錯,在網上找了很多方法,都不行,最後在一個犄角旮旯里找到如下方法

Workbook wb=WorkbookFactory.create(file.getInputStream); 

 

用的maven依賴(版本號最好一致,否則容易出錯)

<dependency>
   <groupId>org.apache.poi</groupId>
   <artifactId>poi</artifactId>
    <version>3.14-beta1</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>  
     <artifactId>poi-ooxml</artifactId>  
     <version>3.14-beta1</version>  
</dependency>  
<dependency>  
    <groupId>org.apache.poi</groupId>  
    <artifactId>poi-ooxml-schemas</artifactId>  
    <version>3.14-beta1</version>  
</dependency> 

 

原文網址::http://www.itnose.net/detail/6144353.html

 

springmvc上傳excel解析存到資料庫原文博客:http://blog.csdn.net/jinwufeiyang/article/details/52216218

將原博客以下方法稍作了修改。

public List<Customer> getExcelInfo(String fileName, MultipartFile Mfile) {
    List<Customer> customerList = new ArrayList<Customer>();
    try {
        // 驗證文件名是否合格
        if (!validateExcel(fileName)) {
            return null;
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
    // 根據文件名判斷文件是2003版本還是2007版本
    boolean isExcel2003 = true;
    if (WDWUtil.isExcel2007(fileName)) {
        isExcel2003 = false;
    }
    try {
        customerList = getExcelInfo(Mfile.getInputStream(), isExcel2003);
    } catch (IOException e) {
        e.printStackTrace();
    }
    return customerList;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 英文文檔: bin(x) Convert an integer number to a binary string. The result is a valid Python expression. If x is not a Python int object, it has to define ...
  • 英文文檔: any(iterable) Return True if any element of the iterable is true. If the iterable is empty, return False. Equivalent to: 說明: 1. 接受一個可迭代器對象為參數,當參 ...
  • 英文文檔: ascii(object) As repr(), return a string containing a printable representation of an object, but escape the non-ASCII characters in the string r ...
  • JSTL和EL的使用 使用JSTL前的準備 想要使用JSTL,首先需要給工程導入JSTL的包(JSTL.jar和standard.jar). JSTL標簽庫 在JSTL中分為以下五個標簽 使用不同的標簽的時候需要在JSP中引入不同的庫 核心標簽(Core): 引入標簽庫 <c:set> <c:set ...
  • OSI 七層模型通過七個層次化的結構模型使不同的系統不同的網路之間實現可靠的通訊,因此其最主要的功能就是幫助不同類型的主機實現數據傳輸 。 完成中繼功能的節點通常稱為中繼系統。在OSI七層模型中,處於不同層的中繼系統具有不同的名稱。 一個設備工作在哪一層,關鍵看它工作時利用哪一層的數據頭部信息。網橋 ...
  • 最近我發現了一個有趣的問題,這個問題的答案乍一看下騙過了我的眼睛。看一下這三個類: package com.ds.test; public class Upper { String upperString; public Upper() { Initializer.initialize(this); ...
  • 20161018問題解析請點擊今日問題下方的“【Java每日一題】20161019”查看 今日問題:上面兩個對int類型數組(集合)的求和操作,性能分析哪個更優?(點擊以下“【Java每日一題】20161019”查看20161018問題解析) 題目原發佈於公眾號、簡書:【Java每日一題】20161 ...
  • 前言 國際慣例,本文寫於本人使用《大話設計模式》一書學習設計模式的路上,適用於初學設計模式的道友交流之用,大神誤入,請留下您寶貴的意見,感激不盡; 開閉原則 定義 軟體實體應當對擴展開放,對修改關閉; 特征 1. 對擴展開放:當需要添加新的功能,或者說擴展功能時,我們不需要修改原來的代碼,只需要添加 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...