Spring?boot集成easy?excel實(shí)現(xiàn)導(dǎo)入導(dǎo)出功能
Spring boot集成easy excel實(shí)現(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>
三 實(shí)現(xiàn)簡(jiǎn)單導(dǎo)入
首先定義實(shí)體類
@Data @AllArgsConstructor @NoArgsConstructor public class Device { @ExcelIgnore private Integer id; @ExcelProperty("設(shè)備名稱") private String name; @ExcelProperty("設(shè)備編號(hào)") 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; }
在定義實(shí)體類的時(shí)候,使用到了lombok,需要提前引入lombok的依賴
<!--lombok--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency>
準(zhǔn)備工作完成之后,就可以寫(xiě)一個(gè)簡(jiǎn)單的導(dǎo)入了。如下,我在controller中寫(xiě)了導(dǎo)入方法,通過(guò)EasyExcel的read方法把excel中的數(shù)據(jù)解析成對(duì)應(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"; }
四 實(shí)現(xiàn)簡(jiǎn)單導(dǎo)出
在controller寫(xiě)了簡(jiǎn)單的導(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 會(huì)導(dǎo)致各種問(wèn)題,請(qǐng)直接用瀏覽器或者用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)出功能
請(qǐng)參考easyexcel實(shí)現(xiàn)批量導(dǎo)出功能
總結(jié)
使用easyexcel實(shí)現(xiàn)導(dǎo)入和導(dǎo)出確實(shí)是非常方便的,同時(shí),easyexcel還支持批量導(dǎo)入和批量導(dǎo)出,確實(shí)非常nice。
到此這篇關(guān)于Spring boot集成easy excel實(shí)現(xiàn)導(dǎo)入導(dǎo)出操作的文章就介紹到這了,更多相關(guān)Spring boot集成easy excel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot EasyPoi動(dòng)態(tài)導(dǎo)入導(dǎo)出的兩種方式實(shí)現(xiàn)方法詳解
- SpringBoot+Vue實(shí)現(xiàn)EasyPOI導(dǎo)入導(dǎo)出的方法詳解
- 使用SpringBoot+EasyExcel+Vue實(shí)現(xiàn)excel表格的導(dǎo)入和導(dǎo)出詳解
- Spring?Boot?+?EasyExcel實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入導(dǎo)出
- 使用VUE+SpringBoot+EasyExcel?整合導(dǎo)入導(dǎo)出數(shù)據(jù)的教程詳解
- SpringBoot整合EasyExcel實(shí)現(xiàn)文件導(dǎo)入導(dǎo)出
- SpringBoot中EasyExcel實(shí)現(xiàn)Excel文件的導(dǎo)入導(dǎo)出
相關(guān)文章
淺談Java中Lambda表達(dá)式的相關(guān)操作
java8新特性,Lambda是一個(gè)匿名函數(shù),類似Python中的Lambda表達(dá)式、js中的箭頭函數(shù),目的簡(jiǎn)化操作,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06基于Java的Socket多客戶端Client-Server聊天程序的實(shí)現(xiàn)
這篇文章主要介紹了基于Java的Socket多客戶端Client-Server聊天程序的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Java調(diào)用Oss JDk實(shí)現(xiàn)刪除指定目錄下的所有文件
這篇文章主要為大家詳細(xì)介紹了Java如何調(diào)用Oss JDk實(shí)現(xiàn)刪除指定目錄下的所有文件功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2025-03-03java導(dǎo)出數(shù)據(jù)庫(kù)的全部表到excel
這篇文章主要為大家詳細(xì)介紹了java導(dǎo)出數(shù)據(jù)庫(kù)的全部表到excel的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03Java程序結(jié)構(gòu)與常量變量難點(diǎn)解析
JAVA的基本結(jié)構(gòu)就是順序結(jié)構(gòu),除非特別指明,否則就按照順序一句一句執(zhí)行順序結(jié)構(gòu)是最簡(jiǎn)單的算法結(jié)構(gòu),語(yǔ)句與語(yǔ)句之間,框與框之間是按從上到下的順序進(jìn)行的,它是由若干個(gè)依次執(zhí)行的處理步驟組成的,它是任何一個(gè)算法都離不開(kāi)的一種基本算法結(jié)構(gòu)2021-10-10Spring原生Rpc六種的正確打開(kāi)方式實(shí)現(xiàn)示例
這篇文章主要為大家展示了Spring原生Rpc六種的正確打開(kāi)方式實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進(jìn)步早日升職加薪2022-02-02Java設(shè)計(jì)模式之命令模式CommandPattern詳解
這篇文章主要介紹了Java設(shè)計(jì)模式之命令模式CommandPattern詳解,命令模式是把一個(gè)請(qǐng)求封裝為一個(gè)對(duì)象,從而使你可用不同的請(qǐng)求對(duì)客戶進(jìn)行參數(shù)化;對(duì)請(qǐng)求排隊(duì)或記錄請(qǐng)求日志,以及支持可撤銷的操作,需要的朋友可以參考下2023-10-10