java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能
前言
poi的解析方式是dom解析,把結(jié)果一次都讀入內(nèi)存操作,這樣的操作平時(shí)是不會(huì)有問(wèn)題的,但是并發(fā)量上來(lái)的時(shí)候就會(huì)出現(xiàn)OOM,EasyExcel,底層對(duì)象其實(shí)還是使用poi包的那一套。它只是將poi包的一部分抽了出來(lái),摒棄掉了大部分業(yè)務(wù)相關(guān)的屬性。由于它關(guān)注的業(yè)務(wù)是導(dǎo)入導(dǎo)出這一塊,所以在處理大數(shù)據(jù)量的導(dǎo)入導(dǎo)出能夠通過(guò)本地緩存來(lái)避免OOM,在特定場(chǎng)景中,EasyExcel的表現(xiàn)能力還是可以的。
1先添加依賴(lài)
<!-- EasyExcel --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.2.0-beta2</version> </dependency>
2批量插入數(shù)據(jù)
再試下導(dǎo)入導(dǎo)出功能前,寫(xiě)批量插入數(shù)據(jù)的接口和查詢(xún)數(shù)據(jù)的接口。
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="cn.demo.mapper.MedicnesMapper"> <insert id="saveMedicnesList" parameterType="cn.demo.entity.Medicnes"> insert into medices (food,remark) values <foreach collection="list" item="rm" separator=","> (#{rm.food},#{rm.remark}) </foreach> </insert> <select id="medicnesList" parameterType="cn.demo.entity.Medicnes" resultType="cn.demo.entity.Medicnes"> SELECT food, remark FROM medices </select> </mapper>
3創(chuàng)建需要導(dǎo)出數(shù)據(jù)實(shí)體類(lèi)
package cn.demo.entity; import com.alibaba.excel.annotation.ExcelProperty; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor public class Medicnes { @ExcelProperty("食物名稱(chēng)") private String food; @ExcelProperty("食物產(chǎn)地") private String remark; }
4創(chuàng)建一個(gè)類(lèi)ExcelListener
package cn.demo.config; import cn.demo.entity.Medicnes; import cn.demo.service.EmpService; import com.alibaba.excel.context.AnalysisContext; import com.alibaba.excel.event.AnalysisEventListener; import org.springframework.beans.factory.annotation.Autowired; import java.util.ArrayList; import java.util.List; /** * 有個(gè)很重要的點(diǎn) ExcelListener * 不能被spring管理,要每次讀取excel都要new,然后里面用到spring可以構(gòu)造方法傳進(jìn)去 */ public class ExcelListener extends AnalysisEventListener<Medicnes> { private List<Medicnes> list = new ArrayList<>(); //每隔5條存儲(chǔ)數(shù)據(jù)庫(kù),實(shí)際使用中可以3000條,然后清理list ,方便內(nèi)存回收 private static final int BATCH_COUNT = 5; //假設(shè)這個(gè)是一個(gè)DAO,當(dāng)然有業(yè)務(wù)邏輯這個(gè)也可以是一個(gè)service。當(dāng)然如果不用存儲(chǔ)這個(gè)對(duì)象用 @Autowired private EmpService empService; /** * 如果使用了spring,請(qǐng)使用這個(gè)構(gòu)造方法。 * 每次創(chuàng)建Listener的時(shí)候需要把spring管理的類(lèi)傳進(jìn)來(lái) */ public ExcelListener(EmpService empService) { this.empService = empService; } /** * 這個(gè)每一條數(shù)據(jù)解析都會(huì)來(lái)調(diào)用 */ @Override public void invoke(Medicnes goods, AnalysisContext analysisContext) { System.out.println("解析到一條數(shù)據(jù):========================"+goods.toString()); // 數(shù)據(jù)存儲(chǔ)到data,供批量處理或后續(xù)自己業(yè)務(wù)邏輯處理。 list.add(goods); // 達(dá)到BATCH_COUNT了,需要去存儲(chǔ)一次數(shù)據(jù)庫(kù),防止數(shù)據(jù)幾萬(wàn)條數(shù)據(jù)在內(nèi)存,容易OOM if(list.size() >= BATCH_COUNT){ saveData(); // 存儲(chǔ)完成清理data list.clear(); } } /** * 所有數(shù)據(jù)解析完成了 都會(huì)來(lái)調(diào)用 */ @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { //確保所有數(shù)據(jù)都能入庫(kù) saveData(); } /** * 加上存儲(chǔ)數(shù)據(jù)庫(kù) */ private void saveData() { System.out.println("=============================="+list.size()+"條數(shù)據(jù),開(kāi)始存儲(chǔ)到數(shù)據(jù)庫(kù)"); empService.saveMedicnesList(list); } }
5實(shí)現(xiàn)下載excel
接下來(lái)編寫(xiě)我們的工具類(lèi)--幫助我們來(lái)實(shí)現(xiàn)下載excel
public class DownExcel { public static void download(HttpServletResponse response, Class t, List list) throws IOException, IllegalAccessException,InstantiationException { response.setContentType("application/vnd.ms-excel");// 設(shè)置文本內(nèi)省 response.setCharacterEncoding("utf-8");// 設(shè)置字符編碼 response.setHeader("Content-disposition", "attachment;filename=demo.xlsx"); // 設(shè)置響應(yīng)頭 EasyExcel.write(response.getOutputStream(), t).sheet("模板").doWrite(list); //用io流來(lái)寫(xiě)入數(shù)據(jù) } } //導(dǎo)出為Excel @RequestMapping("/downloadexcel.do") public void getExcel(HttpServletResponse response) throws IllegalAccessException, IOException, InstantiationException { List<Medicnes> list = sysUserService.medicnesList(); DownExcel.download(response,Medicnes.class,list); }
6控制器添加我們的導(dǎo)入操作代碼
//導(dǎo)入Excel @RequestMapping("/importexcel.do") @ResponseBody public String importexcel(@RequestParam(value = "excelFile") MultipartFile file) throws IOException{ EasyExcel.read(file.getInputStream(), Medicnes.class, new ExcelListener(sysUserService)).sheet().doRead(); return "success"; }
7導(dǎo)出效果如圖
8導(dǎo)入直接調(diào)用
到此這篇關(guān)于java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能的文章就介紹到這了,更多相關(guān)java easyexce 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- java實(shí)現(xiàn)Excel的導(dǎo)入、導(dǎo)出
- Java實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)的方法示例
- java實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出
- Java中Easypoi實(shí)現(xiàn)excel多sheet表導(dǎo)入導(dǎo)出功能
- java使用EasyExcel導(dǎo)入導(dǎo)出excel
- Java實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出操作詳解
- java操作excel導(dǎo)入導(dǎo)出的3種方式
- Java使用EasyExcel實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出
- Java如何使用poi導(dǎo)入導(dǎo)出excel工具類(lèi)
- java如何在項(xiàng)目中實(shí)現(xiàn)excel導(dǎo)入導(dǎo)出功能
相關(guān)文章
關(guān)于@Value注入List,Map及設(shè)置默認(rèn)值問(wèn)題
這篇文章主要介紹了@Value注入List,Map及設(shè)置默認(rèn)值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05SpringBoot整合Drools的實(shí)現(xiàn)步驟
Drools是一個(gè)易于訪問(wèn)企業(yè)策略、易于調(diào)整以及易于管理的開(kāi)源業(yè)務(wù)規(guī)則引擎,符合業(yè)內(nèi)標(biāo)準(zhǔn),速度快、效率高。業(yè)務(wù)分析師或?qū)徍巳藛T可以利用它輕松查看業(yè)務(wù)規(guī)則,從而檢驗(yàn)是否已編碼的規(guī)則執(zhí)行所需的業(yè)務(wù)規(guī)則。本文將講述SpringBoot整合Drools的步驟2021-05-05mybatis?@InsertProvider報(bào)錯(cuò)問(wèn)題及解決
這篇文章主要介紹了mybatis?@InsertProvider報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07SpringBoot執(zhí)行有返回值的異步任務(wù)問(wèn)題
這篇文章主要介紹了SpringBoot執(zhí)行有返回值的異步任務(wù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07Spring中@RabbitHandler和@RabbitListener的區(qū)別詳析
@RabbitHandler是用于處理消息的方法注解,它與@RabbitListener注解一起使用,這篇文章主要給大家介紹了關(guān)于Spring中@RabbitHandler和@RabbitListener區(qū)別的相關(guān)資料,需要的朋友可以參考下2024-02-02使用log4j2自定義配置文件位置和文件名(附log4j2.xml配置實(shí)例)
這篇文章主要介紹了使用log4j2自定義配置文件位置和文件名(附log4j2.xml配置實(shí)例),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12