使用hutool工具進(jìn)行導(dǎo)入導(dǎo)出excel表格
如何在后臺(tái)添加導(dǎo)入導(dǎo)出表格的功能呢,本期的文章將會(huì)帶領(lǐng)小伙伴們一起實(shí)現(xiàn)此功能
1.先引入hutool的相關(guān)依賴
<!--hutool--> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.20</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.2</version> </dependency>
2.導(dǎo)出
創(chuàng)建一個(gè)Controller進(jìn)行測(cè)試
//表格導(dǎo)出接口 @GetMapping("/export") public void export(HttpServletResponse response) throws IOException { //查詢所有用戶 List<User> list= userService.list(); //在內(nèi)存操作,寫到瀏覽器 ExcelWriter writer= ExcelUtil.getWriter(true); //自定義標(biāo)題別名 writer.addHeaderAlias("username","用戶名"); writer.addHeaderAlias("password","密碼"); writer.addHeaderAlias("nickname","昵稱"); writer.addHeaderAlias("email","郵箱"); writer.addHeaderAlias("phone","電話"); writer.addHeaderAlias("address","地址"); writer.addHeaderAlias("createTime","創(chuàng)建時(shí)間"); //默認(rèn)配置 writer.write(list,true); //設(shè)置content—type response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset:utf-8"); //設(shè)置標(biāo)題 String fileName= URLEncoder.encode("用戶信息","UTF-8"); //Content-disposition是MIME協(xié)議的擴(kuò)展,MIME協(xié)議指示MIME用戶代理如何顯示附加的文件。 response.setHeader("Content-Disposition","attachment;filename="+fileName+".xlsx"); ServletOutputStream outputStream= response.getOutputStream(); //將Writer刷新到OutPut writer.flush(outputStream,true); outputStream.close(); writer.close(); }
測(cè)試結(jié)果如下
Vue前端使用這個(gè)代碼進(jìn)行訪問(wèn)即可
//點(diǎn)擊函數(shù)exp, 導(dǎo)出表格 exp(){ window.open("http://localhost:9090/user/export") }
3.導(dǎo)入
創(chuàng)建一個(gè)Controller進(jìn)行測(cè)試
因?yàn)槲仪懊鎸?dǎo)出設(shè)置了別名,所以這里我選擇用第二種方式,
接下來(lái)可以去postman驗(yàn)證是否能實(shí)現(xiàn)功能
/** * 導(dǎo)入excel * @param file */ @PostMapping("/import") public void importExcel(MultipartFile file) throws IOException { //1.第一種 頭必須和實(shí)體(英文)一樣 //文件處理成io流 InputStream in = file.getInputStream(); // //io流給ExcelReader ExcelReader excelReader=ExcelUtil.getReader(in); // //讀取數(shù)據(jù)且轉(zhuǎn)化為list // List<User> list = excelReader.readAll(User.class); //2.第二種導(dǎo)入方式 //忽略第一行頭(第一行是中文的情況),直接讀取表的內(nèi)容 List<List<Object>> list = excelReader.read(1); List<User> listUser = CollUtil.newArrayList(); for (List<Object> row: list) { User user=new User(); user.setUsername(row.get(0).toString()); user.setPassword(row.get(1).toString()); user.setNickname(row.get(2).toString()); user.setNickname(row.get(3).toString()); user.setPhone(row.get(4).toString()); user.setAddress(row.get(5).toString()); listUser.add(user); // ****類似一一對(duì)應(yīng)**** } //批量注冊(cè)進(jìn)數(shù)據(jù)庫(kù) userService.saveBatch(listUser); }
前端的話我是用的elemen-ui
<el-upload action="http://localhost:9090/user/import" :show-file-list="false" accept="xlsx" :on-success="handleImportSuccess" style="display: inline-block;margin-right: 5px"> <el-button type="primary">導(dǎo)入 <i class="el-icon-bottom"></i></el-button> </el-upload>
on-success是一個(gè)鉤子函數(shù),彈了一個(gè)插入成功的信息跟刷新頁(yè)面的操作
//導(dǎo)入,鉤子函數(shù)進(jìn)行頁(yè)面的提示跟成功后頁(yè)面的刷新 handleImportSuccess(){ this.$message.success("導(dǎo)入成功") this.load(); }
4.效果圖
以上就是使用hutool工具進(jìn)行導(dǎo)入導(dǎo)出excel表格的詳細(xì)內(nèi)容,更多關(guān)于hutool導(dǎo)入導(dǎo)出excel表格的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
在SpringBoot中使用YourKit進(jìn)行性能調(diào)優(yōu)的教程詳解
在應(yīng)用程序的開(kāi)發(fā)過(guò)程中,性能調(diào)優(yōu)是一個(gè)重要的環(huán)節(jié),在SpringBoot應(yīng)用程序中,我們可以使用YourKit來(lái)進(jìn)行性能調(diào)優(yōu),YourKit是一款非常強(qiáng)大的Java性能調(diào)優(yōu)工具,在本文中,我們將介紹如何在 SpringBoot應(yīng)用程序中使用YourKit進(jìn)行性能調(diào)優(yōu)2023-06-06深入了解JVM(Java虛擬機(jī))內(nèi)存結(jié)構(gòu)
Java虛擬機(jī)(Java Virtual Machine,JVM)是Java程序的運(yùn)行環(huán)境,它是一個(gè)抽象的計(jì)算機(jī)模型,通過(guò)解釋和執(zhí)行Java字節(jié)碼來(lái)運(yùn)行Java程序,本將大家深入了解JVM(Java虛擬機(jī))內(nèi)存結(jié)構(gòu),需要的朋友可以參考下2023-08-08深入淺析Mybatis與Hibernate的區(qū)別與用途
這篇文章主要介紹了Mybatis與Hibernate的區(qū)別與用途的相關(guān)資料,需要的朋友可以參考下2017-10-10Java中驗(yàn)證 Mybatis 數(shù)據(jù)分片可以減輕GC壓力的操作方法
這篇文章主要介紹了Java中驗(yàn)證 Mybatis 數(shù)據(jù)分片可以減輕GC壓力的操作方法,本文使用 Spock(可集成Spring Boot項(xiàng)目) 編寫測(cè)試用例,基于 Groovy (JVM語(yǔ)言),感興趣的朋友跟隨小編一起看看吧2024-12-12IDEA中創(chuàng)建maven項(xiàng)目webapp目錄無(wú)法識(shí)別即未被標(biāo)識(shí)的解決辦法
在學(xué)習(xí)SpringMVC課程中,基于IDEA新建maven項(xiàng)目模塊后,webapp目錄未被標(biāo)識(shí),即沒(méi)有小藍(lán)點(diǎn)的圖標(biāo)顯示,所以本文給大家介紹了IDEA中創(chuàng)建maven項(xiàng)目webapp目錄無(wú)法識(shí)別即未被標(biāo)識(shí)的解決辦法,需要的朋友可以參考下2024-03-03