您好,登錄后才能下訂單哦!
提到Excel的導入導出,大家肯定都知道alibaba開源的EasyExcel,該項目的github地址為:https://github.com/alibaba/easyexcel。
這個項目非常活躍,項目誕生的目的就是為了簡化開發、降低內存消耗。我項目中也用過,但還是有一些槽點的,比如文檔很簡陋,功能做的不完善,不支持圖片的讀取等。所以,今天給大家推薦另外一款Excel處理的工具:EasyPoi。
一、EasyPoi簡介
官網:http://www.afterturn.cn/
文檔:http://easypoi.mydoc.io/
EasyPoi功能如同名字easy,主打的功能就是容易,讓一個沒見接觸過poi的人員 就可以方便的寫出Excel導出,Excel模板導出,Excel導入,Word模板導出,通過簡單的注解和模板 語言(熟悉的表達式語法),完成以前復雜的寫法 ,不如poi那么自定義,不如jxl那么多標簽,但是我們就是寫的少,寫的少。
EasyPoi的主要特點
二、EasyPoi的功能介紹
Excel自適應xls和xlsx兩種格式,word只支持docx模式,功能還是挺豐富的。
1.Excel導入
2.Excel導出
3.Excel轉html
4.word導出
5.pdf導出
三、重點功能介紹
1.注解
EasyPoi起因就是Excel的導入導出,最初的模板是實體和Excel的對應,model--row,filed--col 這樣利用注解我們可以和容易做到excel到導入導出 經過一段時間發展,現在注解有5個類分別是
2.Excel 模板
模板是處理復雜Excel的簡單方法,復雜的Excel樣式,可以用Excel直接編輯,完美的避開了代碼編寫樣式的雷區,同時指令的支持,也提了模板的有效性。就像下面這樣使用,具體用法請看文檔。
3.Excel<->Html的互轉
4.Word模板導出
5.圖片的導入導出
@Test//圖片導入 public void test() { try { ImportParams params = new ImportParams(); params.setNeedSave(true); List<CompanyHasImgModel> result = ExcelImportUtil.importExcel( new File(PoiPublicUtil.getWebRootPath("import/imgexcel.xls")), CompanyHasImgModel.class, params); for (int i = 0; i < result.size(); i++) { System.out.println(ReflectionToStringBuilder.toString(result.get(i))); } Assert.assertTrue(result.size() == 4); } catch (Exception e) { e.printStackTrace(); } } } //導出 @Excel(name = "公司LOGO", type = 2 ,width = 40 , height = 20,imageType = 1) private String companyLogo;
6.Excel大數據導出
大數據導出是當我們的導出數量在幾萬,到上百萬的數據時,一次從數據庫查詢這么多數據加載到內存然后寫入會對我們的內存和CPU都產生壓力,這個時候需要我們像分頁一樣處理導出分段寫入Excel緩解Excel的壓力 EasyPoi提供的是兩個方法 強制使用 xssf版本的Excel 。具體代碼看文檔,我們看下資源占用即可:
多次測試用時統計,速度還是可以接受的。
數據量 | 用時 | 文件大小 | 列數 |
---|---|---|---|
100W | 16.4s | 24.3MB | 5 |
100W | 15.9s | 24.3MB | 5 |
200W | 29.5s | 48.5MB | 5 |
100W | 30.8s | 37.8MB | 10 |
200W | 58.7s | 76.1MB | 10 |
7.大數據導出View的用法
Easypoi view 項目是為了更簡單的方便搭建在導出時候的操作,利用spring mvc 的view 封裝,更加符合spring mvc的風格。EasypoiBigExcelExportView 是針對大數據量導出特定的View,在跳轉到這個View的時候不需要查詢數據,而且這個View自己去查詢數據,用戶只要實現IExcelExportServer接口就可以了 。
總結,Easypoi的功能強大,文檔和示例代碼豐富,大家在開發中如果有類似的需求,不妨一試。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。