咔片PPT · AI自动生成演示文稿,模板丰富、排版精美 讯飞智文 · 一键生成PPT和Word,高效应对学习与办公

大家好,我是给著名程序员羊羽,今天给大家聊的是SpringBoot+POI导出Excel表格。


页面表格导出Excel是常见的一个需求,可以用前端直接导出也可以经过后端处理后导出,今天我要给大家说的是用后端导出Excel表格。

所需工具/软件/框架

1,eclipse/IDEA;

2,SpringBoot

3,Maven

4,Vue

详细步骤



1,新建一个SpringBoot工程,我想这个应该不用我说了,大家都是有经验的开发人员。



2,在resource目录下新建一个public文件夹(SpringBoot知识,不懂去问度娘);



3,public中新建pages文件夹(随意起)引入vue.js



4,在public下创建一个index.html



5,新建一个domian包并创建一个学生类



6,学生类中创建两个属性并重载构造函数



7,新建一个controller包并创建一个ExcelExport类



8,ExcelExport类中定义一个excelExport方法



9,excelExport方法中就是用来处理表格导出的逻辑

public void excelExport(HttpServletResponse response){ //1,模拟创建数据 List students = new ArrayList<>(); students.add( new Student("张三","男")); students.add( new Student("小红","女")); //2,创建数据表格 //2,创建excel 写到excel中 HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet("学生统计"); //创建第一行 HSSFRow row = sheet.createRow(0); HSSFCell cell0 = row.createCell(0); HSSFCell cell1 = row.createCell(1); cell0.setCellValue("姓名"); cell1.setCellValue("性别"); HSSFRow surveyRow = null; //从集合中获取数据 for (int i = 0; i < students.size(); i++) { Student student = students.get(i); surveyRow = sheet.createRow(i + 1); surveyRow.createCell(0).setCellValue(student.getName()); surveyRow.createCell(1).setCellValue(student.getGender()); } //3,响应给浏览器 try { String fileName = new String("学生性别统计.xls".getBytes("utf-8"),"iso8859-1"); response.setHeader("content-Disposition", "attachment;filename="+fileName); wb.write(response.getOutputStream()); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } }



10,在index.html页面中定义一个button导出表格

<meta charset="UTF-8"> 导出表格

11,点击导出按钮之后,就会下载excel文件了,下载成功后点击打开就行


12,教程结束,收工!

最后

如果看完后有不懂的地方,可以私信来问我,有问必答!

动动你的小手给个赞、评论、转发、收藏,如果可以欢迎打赏!