网站首页 > 技术文章 正文
大家好,我是给著名程序员羊羽,今天给大家聊的是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-09-11 如何将 JSON 文件转换Excel,做为高手的你一定要会哦!
- 2025-09-11 Vue中mixin怎么理解?_vue.mixin是什么
- 2025-09-11 入口开始解读Vue源码系列(二)——new Vue 的故事
- 2025-09-11 【干货】EasyExcel确实好用,Springboot+EasyExcel实操
- 2025-09-11 EXCEL导入—设计与思考_导入设计要考虑哪些因素
- 2025-09-11 条码记录系统 6.0——Excel+Access
- 2025-09-11 系统开发内嵌“在线Excel”教程(1) -- 设计器
- 2025-09-11 Access 与 Excel 的区别:别再把 Excel 当数据库用
- 2024-12-08 公司大佬对excel导入、导出的封装,那叫一个秒啊
- 2024-12-08 如何将 “在线Excel” 嵌入你的开发系统中?
你 发表评论:
欢迎- 最近发表
-
- 用AI做微信小程序的完整步骤_如何用ai制作微信表情包
- 自习室预约的微信小程序设计与实现-计算机毕业设计源码+LW文档
- 微信小程序开发入门指南_微信小程序开发入门教程
- 写字机器人好用吗? 组装就花了5个小时 还要学习软件、录入字体
- 白描网页版 - 高效准确且免费的OCR文字识别工具
- 字体图形面板与图标字体使用_字体图标的优势和劣势
- 作为前端工程师必须懂得的33个CSS核心概念
- Flutter程序员开发炫酷的登录页面 字体库运用 路由学习 源码分享
- 2025Q3开源字体盘点:让你的代码和文档'颜值'飙升!
- Agent杂谈:Agent的能力上下限及「Agent构建」核心技术栈调研分享~
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)