使用easyexcel導(dǎo)出的excel文件,使用poi讀取時異常處理方案
場景
一個導(dǎo)出服務(wù),傳入json數(shù)據(jù),根據(jù)數(shù)據(jù)生成excel文件返回。
別的項(xiàng)目有一個需求,導(dǎo)出文件給用戶修改,修改后再次導(dǎo)入。
之前一直沒有問題,這一天,突然報(bào)了個 【文件讀取失敗】異常?。?!(這里為后臺的自定義異常信息,其原因是POI讀取文件時拋出了異常)
經(jīng)過研究發(fā)現(xiàn),使用服務(wù)導(dǎo)出的excel文件大小是6kb,但是只要打開文件,再保存,哪怕什么都不修改,文件大小會變?yōu)?strong>11kb。然后再次導(dǎo)入時,就能正常導(dǎo)入。(問我之前為什么沒問題?正經(jīng)人導(dǎo)出來肯定是修改了再導(dǎo)回去啊?。。〔蝗辉瓟?shù)據(jù)導(dǎo)回去干嘛?。。。?/p>
但是,問題既然出現(xiàn)了,那肯定要解決嘛。于是,開始了一頓的搜索…肯定是沒有搜索到,不然我就不寫這個了(也可能是搜索得不到位O(∩_∩)O哈哈~)。
環(huán)境
easyexcel 2.2.6版本
找bug
現(xiàn)在下載了一個服務(wù)(使用easyexcel寫的)導(dǎo)出的,沒有經(jīng)過修改的文件A.xlsx,然后復(fù)制了一份并命名B.xlsx.
- A.xlsx 6kb 未修改
- B.xlsx 11kb 原6kb,只是打開后點(diǎn)了保存。沒有動任何數(shù)據(jù)!?。?/li>
現(xiàn)象:
- A文件上傳報(bào)【文件讀取失敗】
- B文件上傳成功
這里把兩個文件后綴改成rar(壓縮文件格式都可以)
然后進(jìn)行了兩個文件的對比,有了以下發(fā)現(xiàn):
- A文件的shardStrings.xml中沒有存放數(shù)據(jù),它的數(shù)據(jù)存在worksheets/sheet1.xml中
- B文件的數(shù)據(jù)存放在shardStrings.xml中,而worksheets/sheet1.xml中只記錄了sheet的一些配置信息
但是直接用office軟件打開,不管哪個顯示都是正常的,沒有報(bào)錯,數(shù)據(jù)也正常,說明它是兼容的,但是保存的時候,office會把A文件的存儲格式轉(zhuǎn)換為B文件。
過程如圖:
思路
我剛開始以為是easyexcel進(jìn)行了數(shù)據(jù)或者文件壓縮導(dǎo)致的,于是我搜索了下,沒有任何有用的信息,浪費(fèi)了我好一會兒時間。
解決
靈機(jī)一動,阿里的,應(yīng)該有官方文檔,搜索了下,真有官方文檔。
最終在文檔在常見問題中找到了這個解決辦法(當(dāng)然,因?yàn)檫@里的業(yè)務(wù)是小模板數(shù)據(jù)填充,不涉及到大數(shù)據(jù)量,所以直接使用,如果有大數(shù)據(jù)量,按文檔的解釋是可能溢出的,各位按自己業(yè)務(wù)場景處理)。
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Eclipse插件開發(fā)實(shí)現(xiàn)控制臺輸出信息的方法
今天小編就為大家分享一篇關(guān)于Eclipse插件開發(fā)實(shí)現(xiàn)控制臺輸出信息的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01Java實(shí)現(xiàn)簡單員工管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡單員工管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02五種SpringBoot實(shí)現(xiàn)數(shù)據(jù)加密存儲的方式總結(jié)
這篇文章主要為大家詳細(xì)介紹了五種常見數(shù)據(jù)加密存儲的方法(結(jié)合SpringBoot和MyBatisPlus框架進(jìn)行實(shí)現(xiàn)),文中的示例代碼講解詳細(xì),需要的可以參考下2023-11-11Java+Springboot搭建一個在線網(wǎng)盤文件分享系統(tǒng)
本主要介紹了通過springboot+freemark+jpa+MySQL實(shí)現(xiàn)的在線網(wǎng)盤文件分享系統(tǒng),其功能跟百度網(wǎng)盤非常類似,可以實(shí)現(xiàn)文件的上傳、移動、復(fù)制、下載等,需要的可以參考一下2021-11-11Java編程guava RateLimiter實(shí)例解析
這篇文章主要介紹了Java編程guava RateLimiter實(shí)例解析,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01