欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot導(dǎo)出Excel的四種方式小結(jié)

 更新時(shí)間:2024年12月16日 10:29:58   作者:brokeSky  
近期接到了一個(gè)小需求,要將系統(tǒng)中的數(shù)據(jù)導(dǎo)出為Excel,且能將Excel數(shù)據(jù)導(dǎo)入到系統(tǒng),對(duì)于大多數(shù)研發(fā)人員來說,這算是一個(gè)最基本的操作了,本文就給大家總結(jié)一下SpringBoot導(dǎo)出Excel的四種實(shí)現(xiàn)方式,需要的朋友可以參考下

方法一:hutools

該方法通過自研的一套Excel注解,在實(shí)體類上添加注解,然后用一套工具類(見源碼中com.leixi.excel.util.excelOne)實(shí)現(xiàn)實(shí)體類列表的導(dǎo)出。優(yōu)點(diǎn)是不用建模板,調(diào)用簡(jiǎn)單,缺點(diǎn)是遷移麻煩。有好幾個(gè)配套的文件如注解,工具類等,想要在別的項(xiàng)目中使用,就涉及到文件的拷貝。老實(shí)說,不太優(yōu)雅,而且更可惜的是,這些方法里居然沒有封裝導(dǎo)出方法。下面給出實(shí)體類創(chuàng)建,方法調(diào)用的代碼,供各位參考(相關(guān)源碼會(huì)在文中提供)

//引入依賴

        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.7.12</version>
        </dependency>
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-base</artifactId>
            <version>4.3.0</version>
        </dependency>
//controller方法,不得不說,調(diào)用起來是真的方便
    @PostMapping(value = "/exportData")
    public ResponseEntity<byte[]> exportData(String fileName) {
        List<ExcelOneDto> list = CommonUtil.buildDemoExcel(ExcelOneDto.class);
        Workbook workbook = new DefaultWriteHandler<ExcelOneDto>().write("sheet名稱",list, ExcelOneDto.class);
        return CommonUtil.exportWorkbook(workbook, fileName);
    }
 
 //實(shí)體類
@Data
public class ExcelOneDto {
    @ExcelCell(priority = "A", cellTitle = "編號(hào)")
    private Integer code;
 
    @ExcelCell(priority = "B", cellTitle = "名稱")
    private String name;
 
 
    @ExcelCell(priority = "C", cellTitle = "詳情")
    private String desc;
 
    @ExcelCell(priority = "D", cellTitle = "備注")
    private String remark;
}

這是導(dǎo)出的測(cè)試結(jié)果:

方法二:easyexcel

現(xiàn)在使用頻率較高的是用easyexcel實(shí)現(xiàn)的。經(jīng)過一番了解,我將easyexcel的實(shí)現(xiàn)方式也列出來作為參考。該方法的優(yōu)點(diǎn)是使用方便,功能強(qiáng)大!本文中我只實(shí)現(xiàn)了最簡(jiǎn)單的導(dǎo)入導(dǎo)出,easyexcel還支持很多如嵌套導(dǎo)入,合并行列等高級(jí)操作,相關(guān)實(shí)現(xiàn)可以參考大神的博客【精選】Spring Boot 集成 EasyExcel 3.x 優(yōu)雅實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出_easyexcel3-CSDN博客。 以下是我學(xué)習(xí)了他的博客后,整理的最基本的代碼:

//引入maven依賴
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.1.3</version>
        </dependency>
//controller:
    @PostMapping(value = "/exportData")
    public void exportData(String fileName, HttpServletResponse response) {
        try {
            this.setExcelResponseProp(response, fileName);
            List<ExcelFourDto> list = CommonUtil.buildDemoExcel(ExcelFourDto.class);;
            EasyExcel.write(response.getOutputStream())
                    .head(ExcelFourDto.class)
                    .excelType(ExcelTypeEnum.XLSX)
                    .sheet(fileName)
                    .doWrite(list);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
 
    @PostMapping("/importData")
    @SneakyThrows
    public Object importUserExcel(@RequestPart("file") MultipartFile file) {
            List<ExcelFourDto> list = EasyExcel.read(file.getInputStream())
                    .head(ExcelFourDto.class).sheet().doReadSync();
            return list;
    }
    
    /**
     * 設(shè)置響應(yīng)結(jié)果
     *
     * @param response    響應(yīng)結(jié)果對(duì)象
     * @param rawFileName 文件名
     * @throws UnsupportedEncodingException 不支持編碼異常
     */
    private void setExcelResponseProp(HttpServletResponse response, String rawFileName) throws UnsupportedEncodingException {
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        response.setCharacterEncoding("utf-8");
        String fileName = URLEncoder.encode(rawFileName, "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
    } 
 
// 實(shí)體類
@Data
public class ExcelFourDto {
    @ExcelProperty("編號(hào)")
    @ColumnWidth(20)
    private Integer code;
 
    @ExcelProperty("名稱")
    @ColumnWidth(20)
    private String name;
 
    @ExcelProperty("詳情")
    @ColumnWidth(20)
    private String desc;
 
    @ExcelProperty("備注")
    @ColumnWidth(20)
    private String remark;
}

以下是測(cè)試結(jié)果:

方法三:ExcelImportUtil工具類

該方法的優(yōu)點(diǎn):不用excel模板,導(dǎo)出導(dǎo)出方便。缺點(diǎn)是封裝的不夠好。研發(fā)人員使用時(shí)需要對(duì)ExcelImportUtil進(jìn)行一定的加工。下面是我封裝后的代碼:

//maven依賴

<dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-base</artifactId>
            <version>4.3.0</version>
        </dependency>
//control類的導(dǎo)入導(dǎo)出
 
    @PostMapping(value = "/importData")
    public Object importManageData(@RequestPart("file") MultipartFile file) throws Exception {
        return CommonUtil.getExcelDataFromFile(file, ExcelTwoDto.class, 1,2);
    }
 
    @PostMapping(value = "/exportData")
    public ResponseEntity<byte[]> exportData(@RequestParam("fileName") String fileName){
        List<ExcelTwoDto> list  = CommonUtil.buildDemoExcel(ExcelTwoDto.class);
        List<Map<String, Object>> exportView = CommonUtil.buildExportView("測(cè)試Title", "測(cè)試Sheet",list);
        Workbook workbook = ExcelExportUtil.exportExcel(exportView, ExcelType.XSSF);
        ExcelStyleUtil.addNotExistCell(workbook, 0, 3);
        return CommonUtil.exportWorkbook(workbook, fileName);
    }
    
//實(shí)體類 
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ExcelTwoDto {
 
    @Excel(name = "第一列" ,fixedIndex = 0, orderNum = "0")
    private String codeOne;
    @Excel(name = "第二列" ,fixedIndex = 1, orderNum = "1", width = 50)
    private String codeTwo;
    @ExcelCollection(name = "第三列" , orderNum = "2")
    private List<ExcelChildDto> codeThree;
 
    @Excel(name = "第四列" ,fixedIndex = 4, orderNum = "4", width = 50)
    private String codeFour;
    @Excel(name = "第五列" ,fixedIndex = 5, orderNum = "5")
    private String codeFive;
    @Excel(name = "第六列A", groupName = "第六列匯總" ,fixedIndex = 6, orderNum = "6")
    private String codeThreeOne;
    @Excel(name = "第六列B", groupName = "第六列匯總" ,fixedIndex = 7, orderNum = "7")
    private String codeThreeTwo;
    @Excel(name = "第六列C", groupName = "第六列匯總" ,fixedIndex = 8, orderNum = "8")
    private String codeThreeThree;
}
 
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ExcelChildDto {
    @Excel(name = "編碼" ,fixedIndex = 0, orderNum = "0")
    private String code;
    @Excel(name = "名稱" ,fixedIndex = 1, orderNum = "1", width = 50)
    private String name;
}

導(dǎo)出測(cè)試結(jié)果:

方法四:Excel模板導(dǎo)出

第三種方案是通過excel模板來實(shí)現(xiàn)的方法,現(xiàn)在基本已經(jīng)廢棄了,之所以放在這里是為了做一個(gè)參照,讓大家看看不同的實(shí)現(xiàn)方法的區(qū)別。這種方式通過創(chuàng)建一個(gè)Excel模板和對(duì)應(yīng)模板的實(shí)體類來實(shí)現(xiàn)文件導(dǎo)出,優(yōu)點(diǎn)是實(shí)體類里不需要加注解了,而且在excel里可以設(shè)計(jì)一些style和格式,缺點(diǎn)是配置excelTemplate太麻煩了。配置繁瑣,且過程中如出現(xiàn)參數(shù)名錯(cuò)誤,符號(hào)錯(cuò)誤等 ,調(diào)試起來很不方便,如果要增減字段,實(shí)體類和excel都得調(diào)整。下面給出編寫的代碼:

// controller方法
    @PostMapping(value = "/exportData")
    public ResponseEntity<byte[]> exportData(@RequestParam("fileName") String fileName) {
        TemplateExportParams params = new TemplateExportParams("templates/template.xlsx");
        params.setScanAllsheet(true);
        Map<String, Object> dataMap = new HashMap<>();
        List<ExcelThreeDto> list  = CommonUtil.buildDemoExcel(ExcelThreeDto.class);
        dataMap.put("titleName", "標(biāo)題名稱");
        dataMap.put("desc", "備注名稱");
        dataMap.put("dataList", list);
        Workbook workbook = ExcelExportUtil.exportExcel(params, dataMap);
        ExcelStyleUtil.setAutoHeight(workbook, 0, 4);
        return CommonUtil.exportWorkbook(workbook, fileName);
    }
    
//實(shí)體類
    @Data
    @Builder
    @NoArgsConstructor
    @AllArgsConstructor
    public class ExcelThreeDto {
        private Integer code;
        private String name;
        private String desc;
        private String remark;
    }

Excel模板的配置

導(dǎo)出的結(jié)果:

由于年代久遠(yuǎn),我沒能找到對(duì)應(yīng)的模板導(dǎo)入的方法,于是在網(wǎng)上搜索了相關(guān)資料,編寫了一個(gè)較通用的文件導(dǎo)入方法:

//maven依賴
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-base</artifactId>
            <version>4.3.0</version>
        </dependency>
/**
     * excel 導(dǎo)入
     */
    @PostMapping("/importData")
    public Object upload(@RequestParam(name = "file") MultipartFile file) {
        return CommonUtil.importExcel(file, 3, ExcelThreeDto.class);
    }
 
    /**
     * 通用的excel導(dǎo)入的方法
     *
     * @param file 導(dǎo)入文件
     * @param startRow 第幾行開始讀數(shù)據(jù)
     * @param clazz 導(dǎo)入后轉(zhuǎn)成的實(shí)體類
     * @return
     * @param <T> 
     */
    @SneakyThrows
    public static <T> List<T> importExcel(MultipartFile file, Integer startRow, Class<T> clazz) {
        Workbook wb = new XSSFWorkbook(file.getInputStream());
        //1.2.獲取Sheet
        Sheet sheet = wb.getSheetAt(0);
        List<T> list = new ArrayList<>();
        Field[] fields = clazz.getDeclaredFields();
        for (int rowNum = startRow; rowNum <= sheet.getLastRowNum(); rowNum++) {
            //根據(jù)索引獲取每一個(gè)行
            Row row = sheet.getRow(rowNum);
            T obj = clazz.newInstance();
            for (int cellNum = 0; cellNum < row.getLastCellNum() && cellNum< fields.length; cellNum++) {
                Cell cell = row.getCell(cellNum);
                Object value = CommonUtil.getCellValue(cell);
                Field field = fields[cellNum];
                field.setAccessible(true);
                // 注意,這里是為了演示,只分析了Integer和String的寫法,實(shí)際上要根據(jù)Field數(shù)據(jù)的枚舉分類處理
                if (field.getType().equals(Integer.class) && value != null) {
                    field.set(obj, new Double(value.toString()).intValue());
                } else {
                    field.set(obj, value);
                }
            }
            list.add(obj);
        }
        return list;
    }

導(dǎo)入的結(jié)果還是蠻令人滿意的:

原以為方法一已經(jīng)是別開生面了,但是對(duì)比起來,仍然是有些差強(qiáng)人意。時(shí)代真是進(jìn)步的飛快,對(duì)于程序員來說,這種變遷顯得尤為明顯。它就像一根鞭子,不斷的抽打著碼農(nóng)們,稍有懈怠就會(huì)被這洪流所淹沒…

(文中附上四種方式的源碼,僅用于學(xué)習(xí)和參考!)

本人力薦前兩種方法,有大量的項(xiàng)目使用,相關(guān)的博客也比較多,尤其是easyexcel,官方對(duì)每種導(dǎo)入導(dǎo)出的方式都有完整的案例參考,簡(jiǎn)單上手!

以上就是SpringBoot導(dǎo)出Excel的四種方式小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot導(dǎo)出Excel方式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot項(xiàng)目統(tǒng)一枚舉轉(zhuǎn)換實(shí)踐過程

    SpringBoot項(xiàng)目統(tǒng)一枚舉轉(zhuǎn)換實(shí)踐過程

    文章介紹了在Spring Boot項(xiàng)目中統(tǒng)一枚舉轉(zhuǎn)換的實(shí)踐,通過使用自定義的父枚舉接口和AttributeConverter、ConverterFactory、JsonSerializer和JsonDeserializer等工具,實(shí)現(xiàn)了枚舉與數(shù)據(jù)庫、請(qǐng)求參數(shù)、響應(yīng)參數(shù)和消息參數(shù)之間的自動(dòng)轉(zhuǎn)換
    2024-12-12
  • Mybatis-Plus之ID自動(dòng)增長(zhǎng)的設(shè)置實(shí)現(xiàn)

    Mybatis-Plus之ID自動(dòng)增長(zhǎng)的設(shè)置實(shí)現(xiàn)

    本文主要介紹了Mybatis-Plus之ID自動(dòng)增長(zhǎng)的設(shè)置實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • java中復(fù)雜查詢sql語句該怎么寫

    java中復(fù)雜查詢sql語句該怎么寫

    我們知道在java連接數(shù)據(jù)庫之后,需要數(shù)據(jù)庫的sql語句,下面這篇文章主要給大家介紹了關(guān)于java中復(fù)雜查詢sql語句該怎么寫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • JAVA封裝多線程實(shí)現(xiàn)的方式及原理

    JAVA封裝多線程實(shí)現(xiàn)的方式及原理

    這篇文章主要介紹了Java中封裝多線程的原理和常見方式,通過封裝可以簡(jiǎn)化多線程的使用,提高安全性,并增強(qiáng)代碼的可維護(hù)性和可擴(kuò)展性,需要的朋友可以參考下
    2025-03-03
  • SpringMVC數(shù)據(jù)頁響應(yīng)ModelAndView實(shí)現(xiàn)頁面跳轉(zhuǎn)

    SpringMVC數(shù)據(jù)頁響應(yīng)ModelAndView實(shí)現(xiàn)頁面跳轉(zhuǎn)

    本文主要介紹了SpringMVC數(shù)據(jù)頁響應(yīng)ModelAndView實(shí)現(xiàn)頁面跳轉(zhuǎn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 解析Java編程之Synchronized鎖住的對(duì)象

    解析Java編程之Synchronized鎖住的對(duì)象

    這篇文章主要介紹了解析Java編程之Synchronized鎖住的對(duì)象,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • 基于SpringBoot+Avue實(shí)現(xiàn)短信通知功能

    基于SpringBoot+Avue實(shí)現(xiàn)短信通知功能

    Avue是基于vue和element-ui的快速開發(fā)框架 ,它的核心是數(shù)據(jù)驅(qū)動(dòng)UI的思想,讓我們從繁瑣的crud開發(fā)中解脫出來,本文將給大家介紹一下使用SpringBoot+Avue實(shí)現(xiàn)短信通知功能,文中有詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-09-09
  • java執(zhí)行shell并獲取shell輸出日志方式

    java執(zhí)行shell并獲取shell輸出日志方式

    這篇文章主要介紹了java執(zhí)行shell并獲取shell輸出日志方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • SpringBoot注解梳理(小結(jié))

    SpringBoot注解梳理(小結(jié))

    這篇文章主要介紹了SpringBoot注解梳理(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Java基礎(chǔ)之包裝類

    Java基礎(chǔ)之包裝類

    這篇文章主要介紹了Java基礎(chǔ)之包裝類,文中有非常詳細(xì)的代碼示例及基礎(chǔ)知識(shí)詳解,對(duì)正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有很大的幫助喲,需要的朋友可以參考下
    2021-05-05

最新評(píng)論