java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能
前言
poi的解析方式是dom解析,把結(jié)果一次都讀入內(nèi)存操作,這樣的操作平時(shí)是不會(huì)有問題的,但是并發(fā)量上來的時(shí)候就會(huì)出現(xiàn)OOM,EasyExcel,底層對(duì)象其實(shí)還是使用poi包的那一套。它只是將poi包的一部分抽了出來,摒棄掉了大部分業(yè)務(wù)相關(guān)的屬性。由于它關(guān)注的業(yè)務(wù)是導(dǎo)入導(dǎo)出這一塊,所以在處理大數(shù)據(jù)量的導(dǎo)入導(dǎo)出能夠通過本地緩存來避免OOM,在特定場(chǎng)景中,EasyExcel的表現(xiàn)能力還是可以的。
1先添加依賴
<!-- EasyExcel -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.0-beta2</version>
</dependency>2批量插入數(shù)據(jù)
再試下導(dǎo)入導(dǎo)出功能前,寫批量插入數(shù)據(jù)的接口和查詢數(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í)體類
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("食物名稱")
private String food;
@ExcelProperty("食物產(chǎn)地")
private String remark;
}4創(chuàng)建一個(gè)類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ù)庫,實(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管理的類傳進(jìn)來
*/
public ExcelListener(EmpService empService) {
this.empService = empService;
}
/**
* 這個(gè)每一條數(shù)據(jù)解析都會(huì)來調(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ù)庫,防止數(shù)據(jù)幾萬條數(shù)據(jù)在內(nèi)存,容易OOM
if(list.size() >= BATCH_COUNT){
saveData();
// 存儲(chǔ)完成清理data
list.clear();
}
}
/**
* 所有數(shù)據(jù)解析完成了 都會(huì)來調(diào)用
*/
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
//確保所有數(shù)據(jù)都能入庫
saveData();
}
/**
* 加上存儲(chǔ)數(shù)據(jù)庫
*/
private void saveData() {
System.out.println("=============================="+list.size()+"條數(shù)據(jù),開始存儲(chǔ)到數(shù)據(jù)庫");
empService.saveMedicnesList(list);
}
}5實(shí)現(xiàn)下載excel
接下來編寫我們的工具類--幫助我們來實(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流來寫入數(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ù)庫的方法示例
- 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工具類
- java如何在項(xiàng)目中實(shí)現(xiàn)excel導(dǎo)入導(dǎo)出功能
相關(guān)文章
關(guān)于@Value注入List,Map及設(shè)置默認(rèn)值問題
這篇文章主要介紹了@Value注入List,Map及設(shè)置默認(rèn)值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
SpringBoot整合Drools的實(shí)現(xiàn)步驟
Drools是一個(gè)易于訪問企業(yè)策略、易于調(diào)整以及易于管理的開源業(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-05
mybatis?@InsertProvider報(bào)錯(cuò)問題及解決
這篇文章主要介紹了mybatis?@InsertProvider報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
SpringBoot執(zhí)行有返回值的異步任務(wù)問題
這篇文章主要介紹了SpringBoot執(zhí)行有返回值的異步任務(wù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Spring中@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

