当前位置:网站首页>直播课堂系统08补-腾讯云对象存储和课程分类管理
直播课堂系统08补-腾讯云对象存储和课程分类管理
2022-08-10 20:54:00 【z754916067】
目录
EasyExcel
介绍
EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。
写操作
创建实体类,设置表头和添加的数据字段
@Data
public class Stu {
//表头名称
@ExcelProperty("学生编号")
private int sno;
@ExcelProperty("学生姓名")
private String sname;
}
public class StuWrite {
//写入excel
private static List<Stu> data(){
ArrayList<Stu> stus = new ArrayList<>();
for(int i=0;i<10;i++){
Stu stu = new Stu();
stu.setSno(i);
stu.setSname("张三"+i);
stus.add(stu);
}
return stus;
}
public static void main(String[] args) {
String filename = "C:\\Users\\y50027918\\Desktop\\aaa.xlsx";
//需要指定数据的class去写 写到哪一个sheet名里 然后文件流会自动关闭
EasyExcel.write(filename,Stu.class).sheet("第一个sheet").doWrite(data());
}
}
EasyExcel读操作
需要创建读取操作的监听器
public class ExcelListener extends AnalysisEventListener<Stu> {
//List集合封装最终的数据
List<Stu> list = new ArrayList<Stu>();
//一行一行去读excel的内容
@Override
public void invoke(Stu stu, AnalysisContext analysisContext) {
System.out.println("***"+stu);
list.add(stu);
}
//读取表头
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
System.out.println("表头信息:"+headMap);
}
//读取完成后执行
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
调用
public static void main(String[] args) {
String filename = "C:\\Users\\y50027918\\Desktop\\aaa.xlsx";
//指定文件名 class 监听者 sheet名 进行读取
EasyExcel.read(filename, Stu.class,
new ExcelListener()).sheet().doRead();
}
功能实现:课程分类导出
首先看一下实体有哪些
编写SubjectService
定义接口方法
//导出
void exportData(HttpServletResponse response);
impl实现
@Override
public void exportData(HttpServletResponse response) {
try {
//设置为excel
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("utf-8");
//给客户端的excel文件名
String filename = URLEncoder.encode("课程分类", "UTF-8");
response.setHeader("Content-disposition", "attachment;filename="+ filename + ".xlsx");
//传null就是所有的意思
List<Subject> subjects = mapper.selectList(null);
//将subject转化成输出的类型
List<SubjectEeVo> dictVoList = new ArrayList<>(subjects.size());
//复制对象
for(Subject dict:subjects){
SubjectEeVo subjectEeVo = new SubjectEeVo();
BeanUtils.copyProperties(dict,subjectEeVo);
dictVoList.add(subjectEeVo);
}
EasyExcel.write(response.getOutputStream(),SubjectEeVo.class).sheet("课程分类").doWrite(dictVoList);
}catch (IOException e){
e.printStackTrace();
}
}
添加controller方法
要向客户机输出数据,需要找response对象,它会在方法的结束自己返回回去。
@ApiOperation("导出")
@GetMapping(value="/exportData")
public void exportData(HttpServletResponse response){
subjectService.exportData(response);
}
数据字典导入前端
在list.vue里添加导出按钮
点击调用exportData方法
<div class="el-toolbar-body" style="justify-content: flex-start;">
<el-button type="text" @click="exportData"><i class="fa fa-plus"/> 导出</el-button>
</div>
编写这个exportData方法,让它调用后台方法
exportData() {
window.open("http://localhost:8301/admin/vod/subject/exportData")
},
功能实现-课程分类导入
导入的话需要监听器,故创建读取监听器,首先创建一个listener文件夹,在其中创建监听器。
//监听的是SubjectEeVo 专门为导出而写的model
@Component
public class SubjectListener extends AnalysisEventListener<SubjectEeVo> {
@Autowired
private SubjectMapper dictmMapper;
//一行一行读取
@Override
public void invoke(SubjectEeVo subjectEeVo, AnalysisContext analysisContext) {
//调用方法添加数据库
Subject subject = new Subject();
//因为和数据库连接的是subject 所以要做转换 存储它
BeanUtils.copyProperties(subjectEeVo,subject);
dictMapper.insert(subject);
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
servece方法添加
首先在接口声明
//导出
void importData(MultipartFile file);
再在impl里面写入
//导入数据
@Override
public void importData(MultipartFile file) {
try{
//文件名 class 监听者
EasyExcel.read(file.getInputStream(),
SubjectEeVo.class,subjectListener).sheet().doRead();
}catch (IOException e) {
e.printStackTrace();
}
}
添加controller方法
在SubjectController里面添加导入的方法
@ApiOperation("导入")
@PostMapping("importData")
public Result<Object> importData(MultipartFile file){
subjectService.importData(file);
return Result.ok(null);
}
数据字典导入前端
一样的,首先添加导入按钮
<el-button type="text" @click="importData"><i class="fa fa-plus"/> 导入</el-button>
再添加点击导入后的弹出层,就在div里添加
<el-dialog title="导入" :visible.sync="dialogImportVisible" width="480px">
<el-form label-position="right" label-width="170px">
<el-form-item label="文件">
<el-upload
:multiple="false"
:on-success="onUploadSuccess"
:action="'http://localhost:8333/admin/vod/subject/importData'"
class="upload-demo">
<el-button size="small" type="primary">点击上传</el-button>
<div slot="tip" class="el-upload__tip">只能上传xls文件,且不超过500kb</div>
</el-upload>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="dialogImportVisible = false">取消</el-button>
</div>
</el-dialog>
注意此时点击是没有用的,需要在后面设置。
前段代码中的visible.sync=“dialogImportVisible”
其意思是dialogImportVisible为true即为弹框,为false即为不弹框。
首先默认为false
data() {
return {
dialogImportVisible: false,
list:[] //数据字典列表数组
}
},
添加导入方法,首先调用importData,让其显示弹框,点击确定后开始解析并且表示成功,再将其调整回false。
importData() {
this.dialogImportVisible = true
},
onUploadSuccess(response, file) {
this.$message.info('上传成功')
this.dialogImportVisible = false
this.getSubList(0)
},
边栏推荐
猜你喜欢
【Windows】你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证的来宾访问,这些策略可帮助保护你的电脑
Future与CompletableFuture
【vulhub】MySql身份认证绕过漏洞复现(CVE-2012-2122)
石油化工行业商业供应链管理系统:标准化供应商管理,优化企业供应链采购流程
详叙c中的分支与循环
OPPO Enco X2 迎来秋季产品升级 旗舰体验全面拉满
【nvm】【node多版本管理工具】使用说明和踩坑(exit status 1)
社区分享|货拉拉通过JumpServer纳管大规模云上资产
带你一文读懂SaaS版多租户商城系统对多品牌企业的应用价值
Knowledge map Knowledge Graph
随机推荐
Knowledge map Knowledge Graph
基于Pix4Dmapper的运动结构恢复法无人机影像三维模型重建
Kubernetes 笔记 / 入门 / 生产环境 / 用部署工具安装 Kubernetes / 用 kubeadm 启动集群 / 用 kubeadm 创建集群
我的世界整合包 云服务器搭建方法(ECS)
sklearn 笔记 TSNE
【ACM】dp专场训练
mysql性能监控与执行计划
Rider调试ASP.NET Core时报thread not gc-safe的解决方法
PostgreSQL — Installation and Common Commands
CGO Preliminary Cognition and Basic Data Type Conversion
通用线程:POSIX 线程详解,第 2部分
Auto.js找图找色常用功能
Redis Command Manual
函数:函数删除操作语法&使用例——《mysql 从入门到内卷再到入土》
【go】依赖注入
【实用软件】【VSCode】使用技巧大全(持续更新)
Single-click to cancel the function
B. Trouble Sort
In 2021 China industrial Internet security competition (competition) in fujian province and the first industry of fujian province Internet innovation competition
用汇编带你看Golang里到底有没有值类型、引用类型