posts - 15, comments - 20, trackbacks - 0, articles - 6
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
                 剛開始使用new HSSFWorkbook(new FileInputStream(excelFile))來讀取Workbook,對Excel2003以前(包括2003)的版本沒有問題,但讀取Excel2007時發(fā)生如下異常:
          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)

                  該錯誤意思是說,文件中的數(shù)據(jù)是用Office2007+XML保存的,而現(xiàn)在卻調(diào)用OLE2 Office文檔處理,應(yīng)該使用POI不同的部分來處理這些數(shù)據(jù),比如使用XSSF來代替HSSF。

                  于是按提示使用XSSF代替HSSF,用new XSSFWorkbook(excelFile)來讀取Workbook,對Excel2007沒有問題了,可是在讀取Excel2003以前(包括2003)的版本時卻發(fā)生了如下新異常(真是太悲劇了):
          org.apache.poi.openxml4j.exceptions.InvalidOperationException: Can't open the specified file: '*.xls'
                  該錯誤是說,操作無效,不能打開指定的xls文件。

                  下載POI的源碼后進(jìn)行單步調(diào)試,發(fā)現(xiàn)剛開始的時候還是對的,但到ZipFile類后就找不到文件了,到網(wǎng)上查了下,原來是XSSF不能讀取Excel2003以前(包括2003)的版本,這樣的話,就需要在讀取前判斷文件是2003前的版本還是2007的版本,然后對應(yīng)調(diào)用HSSF或XSSF來讀取。
                  這是初步的想法,但這種做法比較麻煩,看了下API,發(fā)現(xiàn)XSSF和HSSF雖然在不同的包里,但卻引用了同一接口Workbook,于是想到了這樣的讀取方法:
                  Workbook book = null;
                  try {
                      book = new XSSFWorkbook(excelFile);
                  } catch (Exception ex) {
                      book = new HSSFWorkbook(new FileInputStream(excelFile));
                  }
                  在各版本的Excel中測試,沒有發(fā)生異常,問題解決。

          評論

          # re: 使用POI3.5時,為能兼容Excel2007而發(fā)生的異常[未登錄]  回復(fù)  更多評論   

          2015-10-15 11:46 by 小剛
          讀取PPT怎么辦

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 乌兰浩特市| 射洪县| 天峨县| 禄劝| 桐梓县| 宿松县| 哈密市| 寿宁县| 屏边| 吉安县| 都昌县| 株洲市| 甘孜| 木里| 乡城县| 安乡县| 天台县| 鄂伦春自治旗| 鹤岗市| 通化县| 澜沧| 分宜县| 平谷区| 新龙县| 鄢陵县| 英超| 苗栗市| 大邑县| 牡丹江市| 高台县| 合山市| 阿图什市| 余江县| 邵阳市| 绿春县| 靖边县| 曲水县| 珠海市| 九龙城区| 福海县| 青河县|