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

Spring?boot集成easy?excel實現(xiàn)導(dǎo)入導(dǎo)出功能

 更新時間:2024年05月29日 10:06:57   作者:卿者飛翔  
這篇文章主要介紹了Spring?boot集成easy?excel實現(xiàn)導(dǎo)入導(dǎo)出操作,使用easyexcel,首先要引入easyexcel的maven依賴,具體的版本根據(jù)你的需求去設(shè)置,本文結(jié)合實例代碼講解的非常詳細,需要的朋友可以參考下

Spring boot集成easy excel實現(xiàn)導(dǎo)入導(dǎo)出操作

一 查看官網(wǎng)

easyexcel官方網(wǎng)站地址為easyexcel官網(wǎng),官網(wǎng)的信息比較齊全,可以查看官網(wǎng)使用easyexcel的功能。

二 引入依賴

使用easyexcel,首先要引入easyexcel的maven依賴,具體的版本根據(jù)你的需求去設(shè)置。

        <!--easyexcel-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.10</version>
        </dependency>

三 實現(xiàn)簡單導(dǎo)入

首先定義實體類

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Device {
    @ExcelIgnore
    private Integer id;
    @ExcelProperty("設(shè)備名稱")
    private String name;
    @ExcelProperty("設(shè)備編號")
    private String no;
    @ExcelProperty("設(shè)備描述")
    private String description;
    @ExcelProperty("設(shè)備類型")
    private Integer type;
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ExcelIgnore
    private LocalDateTime createTime;
    @ExcelIgnore
    private Integer status;
}

在定義實體類的時候,使用到了lombok,需要提前引入lombok的依賴

        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>

準(zhǔn)備工作完成之后,就可以寫一個簡單的導(dǎo)入了。如下,我在controller中寫了導(dǎo)入方法,通過EasyExcel的read方法把excel中的數(shù)據(jù)解析成對應(yīng)的列表,然后就可以直接調(diào)用service導(dǎo)入了。

    @RequestMapping("save")
    public String save(MultipartFile file) throws IOException {
        String originalFilename = file.getOriginalFilename();
        List<Device> list = EasyExcel.read(file.getInputStream()).head(Device.class).sheet().doReadSync();
        deviceService.batchSave(list);
        return "redirect:/device/lists";
    }

四 實現(xiàn)簡單導(dǎo)出

在controller寫了簡單的導(dǎo)出方法,拿到service得到的數(shù)據(jù),就可以直接調(diào)用EasyExcel的write方法導(dǎo)出了。

@GetMapping("export")
    public void export(Dto dto,HttpServletResponse response) throws IOException {
        // 這里注意 有同學(xué)反應(yīng)使用swagger 會導(dǎo)致各種問題,請直接用瀏覽器或者用postman
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        response.setCharacterEncoding("utf-8");
        // 這里URLEncoder.encode可以防止中文亂碼 
        String fileName = URLEncoder.encode("設(shè)備數(shù)據(jù)", "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
        List<Device> deviceList = deviceService.getDeviceList(dto);
        EasyExcel.write(response.getOutputStream(), Device.class).sheet("數(shù)據(jù)").doWrite(deviceList);
    }

五 批量導(dǎo)出功能

請參考easyexcel實現(xiàn)批量導(dǎo)出功能

總結(jié)

使用easyexcel實現(xiàn)導(dǎo)入和導(dǎo)出確實是非常方便的,同時,easyexcel還支持批量導(dǎo)入和批量導(dǎo)出,確實非常nice。

到此這篇關(guān)于Spring boot集成easy excel實現(xiàn)導(dǎo)入導(dǎo)出操作的文章就介紹到這了,更多相關(guān)Spring boot集成easy excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談Java中Lambda表達式的相關(guān)操作

    淺談Java中Lambda表達式的相關(guān)操作

    java8新特性,Lambda是一個匿名函數(shù),類似Python中的Lambda表達式、js中的箭頭函數(shù),目的簡化操作,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • 基于Java的Socket多客戶端Client-Server聊天程序的實現(xiàn)

    基于Java的Socket多客戶端Client-Server聊天程序的實現(xiàn)

    這篇文章主要介紹了基于Java的Socket多客戶端Client-Server聊天程序的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Java調(diào)用Oss JDk實現(xiàn)刪除指定目錄下的所有文件

    Java調(diào)用Oss JDk實現(xiàn)刪除指定目錄下的所有文件

    這篇文章主要為大家詳細介紹了Java如何調(diào)用Oss JDk實現(xiàn)刪除指定目錄下的所有文件功能,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2025-03-03
  • java自定義異常打印內(nèi)容詳解

    java自定義異常打印內(nèi)容詳解

    這篇文章主要為大家詳細介紹了java自定義異常打印內(nèi)容的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • java導(dǎo)出數(shù)據(jù)庫的全部表到excel

    java導(dǎo)出數(shù)據(jù)庫的全部表到excel

    這篇文章主要為大家詳細介紹了java導(dǎo)出數(shù)據(jù)庫的全部表到excel的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Java開發(fā)必備的三大修飾符

    Java開發(fā)必備的三大修飾符

    JAVA的三個修飾:static,final,abstract,在JAVA語言里無處不在,但是它們都能修飾什么組件,修飾組件的含義又有什么限制,總是混淆.所以來總結(jié)一下,需要的朋友可以參考下
    2021-06-06
  • Java程序結(jié)構(gòu)與常量變量難點解析

    Java程序結(jié)構(gòu)與常量變量難點解析

    JAVA的基本結(jié)構(gòu)就是順序結(jié)構(gòu),除非特別指明,否則就按照順序一句一句執(zhí)行順序結(jié)構(gòu)是最簡單的算法結(jié)構(gòu),語句與語句之間,框與框之間是按從上到下的順序進行的,它是由若干個依次執(zhí)行的處理步驟組成的,它是任何一個算法都離不開的一種基本算法結(jié)構(gòu)
    2021-10-10
  • Spring原生Rpc六種的正確打開方式實現(xiàn)示例

    Spring原生Rpc六種的正確打開方式實現(xiàn)示例

    這篇文章主要為大家展示了Spring原生Rpc六種的正確打開方式實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進步早日升職加薪
    2022-02-02
  • Java設(shè)計模式之命令模式CommandPattern詳解

    Java設(shè)計模式之命令模式CommandPattern詳解

    這篇文章主要介紹了Java設(shè)計模式之命令模式CommandPattern詳解,命令模式是把一個請求封裝為一個對象,從而使你可用不同的請求對客戶進行參數(shù)化;對請求排隊或記錄請求日志,以及支持可撤銷的操作,需要的朋友可以參考下
    2023-10-10
  • Java定義畫板類的方法

    Java定義畫板類的方法

    這篇文章主要為大家詳細介紹了Java定義畫板類的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評論