网站首页 > 技术文章 正文
大家好,我是给著名程序员羊羽,今天给大家聊的是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<Student> 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导出表格
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>导出表格</title>
<script src="pages/vue.js"></script>
</head>
<body>
<div id="app">
<button @click="exportExcel()">点击导出表格</button>
</div>
<script>
var app = new Vue({
el: '#app',
methods:{
exportExcel:function(){
window.open("/excelExport.do");
}
}
})
</script>
</body>
</html>
11,点击导出按钮之后,就会下载excel文件了,下载成功后点击打开就行
12,教程结束,收工!
最后
如果看完后有不懂的地方,可以私信来问我,有问必答!
动动你的小手给个赞、评论、转发、收藏,如果可以欢迎打赏!
猜你喜欢
- 2025-01-08 理解 Next.js 中的 CSR、SSR、SSG、ISR 以及 Streaming
- 2025-01-08 熬夜7天,我总结了JavaScript与ES的25个知识点
- 2025-01-08 Layui 项目前端导出Excel文件总结
- 2025-01-08 [西门子PLC] WinCC 从 SQL 数据库导出数据到 Excel 报表模板
- 2025-01-08 产品说要让excel在线编辑,我是这样做的。
- 2025-01-08 JAVA导出EXCEL表格
- 2025-01-08 js中的import/export
- 2025-01-08 前端必读:如何在 JavaScript 中使用SpreadJS导入和导出 Excel 文件
- 2025-01-08 ES6语法之export default与export区别
- 2025-01-08 前端必读榜——如何在React中用SpreadJS导入/导出Excel文件
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)