亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能

 更新時(shí)間:2022年09月23日 17:09:26   作者:紅姐最牛  
這篇文章主要介紹了java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助

前言

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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于@Value注入List,Map及設(shè)置默認(rèn)值問(wèn)題

    關(guān)于@Value注入List,Map及設(shè)置默認(rèn)值問(wèn)題

    這篇文章主要介紹了@Value注入List,Map及設(shè)置默認(rèn)值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • springboot上傳文件過(guò)大的500異常解決

    springboot上傳文件過(guò)大的500異常解決

    這篇文章主要介紹了springboot上傳文件過(guò)大的500異常解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • SpringBoot整合Drools的實(shí)現(xiàn)步驟

    SpringBoot整合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-05
  • mybatis?@InsertProvider報(bào)錯(cuò)問(wèn)題及解決

    mybatis?@InsertProvider報(bào)錯(cuò)問(wèn)題及解決

    這篇文章主要介紹了mybatis?@InsertProvider報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • SpringBoot執(zhí)行有返回值的異步任務(wù)問(wèn)題

    SpringBoot執(zhí)行有返回值的異步任務(wù)問(wèn)題

    這篇文章主要介紹了SpringBoot執(zhí)行有返回值的異步任務(wù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Spring Boot兩種全局配置和兩種注解的操作方法

    Spring Boot兩種全局配置和兩種注解的操作方法

    Spring Boot使用一個(gè)application.properties或者application.yaml的文件作為全局配置文件,本文重點(diǎn)給大家介紹Spring Boot兩種全局配置和兩種注解的配置方法,感興趣的朋友一起看看吧
    2021-06-06
  • Spring中@RabbitHandler和@RabbitListener的區(qū)別詳析

    Spring中@RabbitHandler和@RabbitListener的區(qū)別詳析

    @RabbitHandler是用于處理消息的方法注解,它與@RabbitListener注解一起使用,這篇文章主要給大家介紹了關(guān)于Spring中@RabbitHandler和@RabbitListener區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • java微信紅包實(shí)現(xiàn)算法

    java微信紅包實(shí)現(xiàn)算法

    這篇文章主要為大家詳細(xì)介紹了java微信紅包實(shí)現(xiàn)算法,列出紅包的核心算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Guava輕松創(chuàng)建和管理不可變集合方法技巧

    Guava輕松創(chuàng)建和管理不可變集合方法技巧

    這篇文章主要為大家介紹了Guava輕松創(chuàng)建和管理不可變集合方法技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 使用log4j2自定義配置文件位置和文件名(附log4j2.xml配置實(shí)例)

    使用log4j2自定義配置文件位置和文件名(附log4j2.xml配置實(shí)例)

    這篇文章主要介紹了使用log4j2自定義配置文件位置和文件名(附log4j2.xml配置實(shí)例),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評(píng)論