Java使用easyExcel實現(xiàn)導(dǎo)入功能
今天帶來的是esayExcel的簡單使用小結(jié),一個高效的Excel的處理框架
臨時接到領(lǐng)導(dǎo)要求需要做一個Excel導(dǎo)入功能,于是發(fā)揮我的特長——面向百度編程。
在百度搜索了一圈都是POi導(dǎo)入方式,找到一個看著還算靠譜的demo,這種方式在我看來相當(dāng)?shù)谋恐?,讀取到Excel內(nèi)容后逐個進行判斷。折騰了一個上午,代碼像是一個年邁的老人-巋然不動,為我的菜感到汗顏。
經(jīng)過公司經(jīng)驗豐富的老人的指導(dǎo),使用阿里巴巴開源的easyExcel導(dǎo)入方式使用很便捷,更重要的是快,十分鐘就完成了整個導(dǎo)入過程的開發(fā)。
書歸正傳,正式進入easyExcel的使用過程。
一、導(dǎo)入依賴
<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的表頭對應(yīng)。
三、寫操作
@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;
}調(diào)用 EasyExcel.read()方法,需要傳遞三個參數(shù),1、文件流 2、實體類 3、new ImportMedicineService(updateSupport,medicineBasicMapper)處理的業(yè)務(wù)類
四、業(yè)務(wù)實現(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;
}
// 每讀取一行就調(diào)用該方法
@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);
}
// 全部讀取完成就調(diào)用該方法
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
medicineBasicMapper.insertList(list);
}當(dāng)我們調(diào)用導(dǎo)入接口時會調(diào)用到 AnalysisEventListener 的實現(xiàn)類的invoke()方法,但是每讀取一行都會執(zhí)行invoke()方法,大部分業(yè)務(wù)場景都會把讀取的內(nèi)容存入到數(shù)據(jù)庫中,如果讀取一行就保存到數(shù)據(jù)庫,這對于數(shù)據(jù)庫來說簡直是一個災(zāi)難。
比較好的方式就是在doAfterAllAnalysed()方法中執(zhí)行數(shù)據(jù)庫的操作,將多次數(shù)據(jù)庫IO轉(zhuǎn)為一次IO。
這種方式是不是比PIO要簡單一些呢?
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
解決SpringMVC接收不到ajaxPOST參數(shù)的問題
今天小編就為大家分享一篇解決SpringMVC接收不到ajaxPOST參數(shù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Springboot整合logback多節(jié)點日志文件加端口號區(qū)分的操作方法
這篇文章主要介紹了Springboot整合logback多節(jié)點日志文件加端口號區(qū)分的操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
Java調(diào)用py或者exe文件實現(xiàn)Word轉(zhuǎn)PDF
這篇文章主要為大家詳細介紹了Java如何調(diào)用py或者exe文件實現(xiàn)Word轉(zhuǎn)PDF效果,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解下2025-03-03
詳解mybatis collection標(biāo)簽一對多的使用
這篇文章主要介紹了mybatis collection標(biāo)簽一對多的使用,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06

