Java使用easyExcel實現(xiàn)導入功能
今天帶來的是esayExcel的簡單使用小結,一個高效的Excel的處理框架
臨時接到領導要求需要做一個Excel導入功能,于是發(fā)揮我的特長——面向百度編程。
在百度搜索了一圈都是POi導入方式,找到一個看著還算靠譜的demo,這種方式在我看來相當?shù)谋恐兀x取到Excel內容后逐個進行判斷。折騰了一個上午,代碼像是一個年邁的老人-巋然不動,為我的菜感到汗顏。
經(jīng)過公司經(jīng)驗豐富的老人的指導,使用阿里巴巴開源的easyExcel導入方式使用很便捷,更重要的是快,十分鐘就完成了整個導入過程的開發(fā)。
書歸正傳,正式進入easyExcel的使用過程。
一、導入依賴
<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.1</version> </dependency>
二、編寫entity類
public class MedicineBasicImport implements Serializable { /** * 藥品編碼 */ @ExcelProperty("藥品編碼") private String code; /** * 藥品類型 */ @ExcelProperty( "藥品類型") private String type; /** * 藥品名稱 */ @ExcelProperty("藥品名稱") private String title; }
特別指出的是,實體屬性上需要增加 @ExcelProperty注解與Excel的表頭對應。
三、寫操作
@Override public int importBasicMedicine(MultipartFile file, Long updateSupport) { try { BufferedInputStream bufferedInputStream=new BufferedInputStream(file.getInputStream()); EasyExcel.read(bufferedInputStream, MedicineBasicImport.class,new ImportMedicineService(updateSupport,medicineBasicMapper)) .sheet() .doRead();; } catch (IOException e) { e.printStackTrace(); } return 0; }
調用 EasyExcel.read()方法,需要傳遞三個參數(shù),1、文件流 2、實體類 3、new ImportMedicineService(updateSupport,medicineBasicMapper)處理的業(yè)務類
四、業(yè)務實現(xiàn)
ImportMedicineService需要我們繼承 AnalysisEventListener類 并實現(xiàn)它的兩個方法,invoke()和doAfterAllAnalysed()方法。
public class ImportMedicineService extends AnalysisEventListener<MedicineBasicImport> { private Long topDeptId; private TMedicineBasicMapper medicineBasicMapper; List<TMedicineBasic> list = new ArrayList<>(); public ImportMedicineService(Long updateSupport, TMedicineBasicMapper medicineBasicMapper) { topDeptId=updateSupport; this.medicineBasicMapper=medicineBasicMapper; } // 每讀取一行就調用該方法 @Override public void invoke(MedicineBasicImport data, AnalysisContext context) { TMedicineBasic tMedicineBasic=new TMedicineBasic(); tMedicineBasic.setId(IdUtils.simpleUUID()); tMedicineBasic.setTopDeptId(topDeptId); BeanUtils.copyProperties(data,tMedicineBasic); list.add(tMedicineBasic); } // 全部讀取完成就調用該方法 @Override public void doAfterAllAnalysed(AnalysisContext context) { medicineBasicMapper.insertList(list); }
當我們調用導入接口時會調用到 AnalysisEventListener 的實現(xiàn)類的invoke()方法,但是每讀取一行都會執(zhí)行invoke()方法,大部分業(yè)務場景都會把讀取的內容存入到數(shù)據(jù)庫中,如果讀取一行就保存到數(shù)據(jù)庫,這對于數(shù)據(jù)庫來說簡直是一個災難。
比較好的方式就是在doAfterAllAnalysed()方法中執(zhí)行數(shù)據(jù)庫的操作,將多次數(shù)據(jù)庫IO轉為一次IO。
這種方式是不是比PIO要簡單一些呢?
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
利用Spring?boot+LogBack+MDC實現(xiàn)鏈路追蹤
這篇文章主要介紹了利用Spring?boot+LogBack+MDC實現(xiàn)鏈路追蹤,MDC?可以看成是一個與當前線程綁定的哈希表,可以往其中添加鍵值對,下文詳細介紹需要的小伙伴可以參考一下2022-04-04SpringCloudConfig之client端報錯Could?not?resolve?placeholder問
這篇文章主要介紹了SpringCloudConfig之client端報錯Could?not?resolve?placeholder?‘from‘?in?value?“${from}“問題及解決方案,具有很好的參考價值,希望對大家有所幫助2022-12-12海量數(shù)據(jù)去重排序bitmap(位圖法)在java中實現(xiàn)的兩種方法
今天小編就為大家分享一篇關于海量數(shù)據(jù)去重排序bitmap(位圖法)在java中實現(xiàn)的兩種方法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-02-02RabbitMQ消息隊列中的Channel信道參數(shù)詳解
這篇文章主要介紹了RabbitMQ消息隊列中的Channel信道參數(shù)詳解,信道是生產消費者與rabbit通信的渠道,生產者publish或者消費者消費一個隊列都是需要通過信道來通信的,信道是建立在TCP上面的虛擬鏈接,需要的朋友可以參考下2023-08-08springboot2.x 接入阿里云市場短信發(fā)送的實現(xiàn)
本文主要介紹了springboot2.x 接入阿里云市場短信發(fā)送的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11