Java整合EasyExcel实战——1

参考:读Excel | Easy Excel快速使用easyexcel的来完成excel的读取icon-default.png?t=N7T8https://easyexcel.opensource.alibaba.com/docs/current/quickstart/read

准备条件

依赖

        <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.0</version></dependency>

工具类

实战

注解

@ExcelIgnore : 忽略字段

@ExcelProperty(value = "教职工编号"),引用此字段

@ExcelProperty(index = 0) ,index行索引,从0开始

@Data
public class DemoMergeData {@ExcelProperty("票据")private String string;@ExcelProperty("日期")private Date date;@ExcelProperty("数字")private Double doubleData;}

导出Excel

service层

    /**** 导出教职工 Excel* @param response* @return*/R<Void>  importExcel(HttpServletResponse response);

controller层

@RestController
@RequestMapping("/ex/test")
public class DemoMergeDataController {@GetMapping("/getTestDemo")public R getTestDemo(HttpServletResponse response) throws IOException {ArrayList<DemoMergeData> objects = getDemoMergeData();// 定义导出的Excel文件名String fileName = "DemoMergeData.xlsx";// 设置响应的内容类型为二进制流,这是文件下载的标准设置response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);// 设置响应头的Content-Disposition,使用"attachment"指示浏览器这是一个需要下载的文件,
// 并使用URLEncoder对文件名进行编码处理,确保文件名的兼容性跨平台和浏览器response.setHeader(HttpHeaders.CONTENT_DISPOSITION, "attachment;filename=" + URLEncoder.encode(fileName, String.valueOf(StandardCharsets.UTF_8)));// 创建并配置写入的单元格样式
// WriteCellStyle用于定义单元格的样式,这里只创建了一个基础样式,未具体设置WriteCellStyle contentStyle = new WriteCellStyle();// 创建水平方向的单元格样式策略,第一个参数为null表示默认的头样式,第二个参数是内容样式
// 这里没有定义头样式,所以所有单元格都会应用contentStyleHorizontalCellStyleStrategy horizontalCellStyleStrategy = new HorizontalCellStyleStrategy(null, contentStyle);// 使用EasyExcel的write方法开始写入Excel,参数分别为:
// 1. 输出流:这里使用response的OutputStream,使得Excel内容直接写入HTTP响应
// 2. 导出数据对应的JavaBean类型
// 然后注册自定义的单元格样式策略EasyExcel.write(response.getOutputStream(), DemoMergeData.class).registerWriteHandler(horizontalCellStyleStrategy)// 定义工作表信息,此处工作表名为"数据Sheet".sheet("数据Sheet")// 执行写入操作,传入准备好的数据列表.doWrite(objects);return R.success();}

导入Excel

service层

    /****  导入*/R<Void> exportExcel(MultipartFile file) throws Exception;

serviceImpl层

    @Overridepublic R importExQuestionOptions(MultipartFile file) throws IOException {ArrayList<ExExcelQuestionOptionsDto> list = new ArrayList<>();// 工具类读取数据EasyExcel.read(file.getInputStream(), ExExcelQuestionOptionsDto.class, new PageReadListener<ExExcelQuestionOptionsDto>(dataList -> {list.addAll(dataList);})).sheet().doRead();System.out.println(list);return R.success();}

controller层

    @PostMapping("/importExQuestionOptions")public R  importExQuestionOptions(@RequestParam("file") MultipartFile file) throws IOException {return exQuestionService.importExQuestionOptions(file);}

注意缓存冲突问题

如果遇到缓存问题,缓存获取不到数据。

需要配置redis缓存,不用默认的redis默认配置

  cache:type: redisredis:time-to-live: 3600000# 缓存null值,防止缓存穿透cache-null-values: true

监听器构造数据

package co.yixiang.exam.listener;import co.yixiang.exam.entity.dto.ExExcelQuestionOptionsDto;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;import java.util.ArrayList;
import java.util.List;/*** @author Mtz* @version 1.0* @2024/5/2514:58* @function* @comment*/
public class ExQuestionDataListener extends AnalysisEventListener<ExExcelQuestionOptionsDto> {private List<ExExcelQuestionOptionsDto> exExcelQuestionOptionsDtoList = new ArrayList<>();@Overridepublic void invoke(ExExcelQuestionOptionsDto exExcelQuestionOptionsDto, AnalysisContext analysisContext) {exExcelQuestionOptionsDtoList.add(exExcelQuestionOptionsDto);}@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {}
}

导入数据

    @Overridepublic R importExQuestionOptions(MultipartFile file) throws IOException {List<ExExcelQuestionOptionsDto> objects = EasyExcel.read(file.getInputStream(),ExExcelQuestionOptionsDto.class, new ExQuestionDataListener()).sheet().doReadSync();System.out.println(objects);return R.success();}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/842150.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 动效整理

Android自定义SeekBar&#xff0c;滑动时弹出气泡指示器显示进度 安卓开发中非常炫的效果集合_android 开发 向右上角收起炫酷动态效果-CSDN博客 https://github.com/shenghuntianlang/Android-Views?tabreadme-ov-file#decentbanner 以前收藏了很多文章&#xff0c;但是过…

【UE5.1 角色练习】08-传送技能

前言 在上一篇&#xff08;【UE5.1 角色练习】07-AOE技能&#xff09;基础上继续实现人物通过鼠标点击然后传送技能的功能。 效果 步骤 1. 首先需要显示鼠标光标&#xff0c;我们可以在玩家控制器中勾选“显示鼠标光标” 2. 在项目设置中添加一个操作映射&#xff0c;设置按…

Python爬虫入门实例:Python7个爬虫小案例(附源码)

引言 随着互联网的快速发展&#xff0c;数据成为了新时代的石油。Python作为一种高效、易学的编程语言&#xff0c;在数据采集领域有着广泛的应用。本文将详细讲解Python爬虫的原理、常用库以及实战案例&#xff0c;帮助读者掌握爬虫技能。 一、爬虫原理 爬虫&#xff0c;又…

2024年上半年信息系统项目管理师下午真题及答案(第二批)

试题一 某项目计划工期为10个月&#xff0c;预算210万元&#xff0c;第7个月结束时&#xff0c;项目经理进行了绩效评估&#xff0c;发现实际完成了总计划进度的70%。项目的实际数据如表所示&#xff1a; 单击下面头像图片领取更多软考独家资料

企业内部通讯软件—WorkPlus适配信创即时通讯软件

在现代企业中&#xff0c;良好的内部通讯是保持高效工作和顺利运营的关键。企业内部通讯软件的选择对于提升沟通效率、促进团队合作、保障数据安全和隐私保护至关重要。本文将介绍企业内部通讯软件的重要性探讨一些常用的软件&#xff0c;帮助企业做出明智的选择。 一、企业内…

深度融合大语言模型与知识图谱:思通数科企业知识库智能问答系统的创新实践

摘要 在知识经济时代&#xff0c;企业知识管理的重要性日益凸显。本文深入探讨了思通数科如何利用大语言模型和知识图谱技术&#xff0c;构建企业知识库智能问答系统&#xff0c;以促进知识的高效获取、共享、应用和创新&#xff0c;从而提升企业的知识管理水平和业务价值。 1…

钕铁硼表面磷化处理

大家都知道烧结钕铁硼易氧化、易腐蚀&#xff0c;日久将造成磁性能的衰减甚至丧失&#xff0c;所以使用前必须进行严格的防腐处理。在之前的文章中已经向大家介绍过与烧结钕铁硼表面处理相关的知识和电镀的工艺流程&#xff0c;除了电镀之外&#xff0c;钕铁硼表面处理还可采用…

Reids高频面试题汇总总结

一、Redis基础 Redis是什么? Redis是一个开源的内存数据存储系统,它可以用作数据库、缓存和消息中间件。Redis支持多种数据结构,如字符串、哈希表、列表、集合、有序集合等,并提供了丰富的操作命令来操作这些数据结构。Redis的主要特点是什么? 高性能:Redis将数据存储在内…

大数据开发面试题【ClickHouse篇】

170、clickhouse介绍以及架构 clickhouse一个分布式列式存储数据库&#xff0c;主要用于在线分析查询 171、列式存储和行式存储有什么区别&#xff1f; 行式存储&#xff1a; 1、数据是按行存储的 2、没有建立索引的查询消耗很大的IO 3、建立索引和视图花费一定的物理空间和…

rapidssl通配符证书低至600元一年

RapidSSL是Geotrust旗下的子品牌&#xff0c;主要经营的是入门级的SSL数字证书。RapidSSL旗下的SSL证书产品不多&#xff0c;只有DV基础型单域名SSL证书和通配符SSL证书&#xff0c;不过这两款SSL证书满足了大多数网站的需求。今天就随SSL盾小编了解RapidSSL旗下的通配符SSL证书…

MybatisPlus中自定义sql

背景 在开发过程中&#xff0c;可能会出现除了where条件&#xff0c;其它sql比较复杂&#xff0c;这时候就需要用到自定义sql了。 问题 如&#xff1a;用户状态为正常的数据年龄加一&#xff08;所有用户年龄加一&#xff09; 数据库中sql&#xff1a; UPDATE USER SET…

协变(List泛型作为方法参数时的父类子类问题)

有段时间没搞.net的项目了&#xff08;没办法&#xff0c;谁让国内JAVA流行是事实&#xff09;。最近又回归.net&#xff08;哪里需要哪里搬~&#xff09;。 接收到需求后&#xff0c;一顿输出&#xff0c;结果…咦?编译失败??? 错误信息&#xff1a; CS1503:参数1:无法…

Docker 常用命令大全!!

Docker 常用命令 一、启动类1. 启动 docker2. 关闭 docker3. 重新启动 docker4. docker 设置自启动5. 查看 docker 运行状态6. 查看 docker 版本号等信息7. docker 帮助 二、 镜像类1. 查看镜像2. 搜索镜像3. 拉取镜像4. 运行镜像5. 删除镜像6. 加载镜像7. 保存镜像 三、容器类…

python-opencv 边缘检测、直线检测、圆检测

文章目录 Canny算法霍夫变换-直线检测霍夫变换-圆形检测 Canny算法 除了将目标与背景分离开来&#xff0c;边缘检测也同样是一种图像分割方法&#xff0c;从分割结果来看&#xff0c;adaptiveThreshold函数显然就采取了类似边缘检测的划分方案。 Canny在1986年提出了一种边缘…

【源码】2024完美运营版商城/拼团/团购/秒杀/积分/砍价/实物商品/虚拟商品等全功能商城

后台可以自由拖曳修改前端UI页面 还支持虚拟商品自动发货等功能 前端UNIAPP 后端PHP 一键部署版本 获取方式&#xff1a; 微&#xff1a;uucodes

代码随想录算法训练营第四十一天|动态规划理论基础、509. 斐波那契数列、70. 爬楼梯、746. 使用最小花费爬楼梯

动态规划理论基础 什么是动态规划 动态规划&#xff0c;英文&#xff1a;Dynamic Programming&#xff0c;简称DP&#xff0c;如果某一问题有很多重叠子问题&#xff0c;使用动态规划是最有效的。 所以动态规划中每一个状态一定是由上一个状态推导出来的&#xff0c;这一点就…

X2Doris使用指南:界面化数据迁移工具 - 轻松实现整库迁移至Doris

什么是X2Doris X2Doris 是 SelectDB 团队开发的&#xff0c;专门用于将各种离线数据迁移到 Apache Doris 中的核心工具&#xff0c;该工具集 自动建 Doris 表 和 数据迁移 为一体&#xff0c;目前支持了 Apache Doris/Hive/Kudu/StarRocks 数据库往 Doris 或 SelectDB Cloud 迁…

一屏万象,场景无限:蓝牙墨水屏标签多功能多场景应用带您领略未来

在数字化浪潮汹涌澎湃的今天&#xff0c;智能科技产品层出不穷&#xff0c;它们不仅极大地改变了我们的生活方式&#xff0c;更在无形中拓宽了我们的视野。而今&#xff0c;一款融合了创新技术与实用性于一体的蓝牙墨水屏标签&#xff0c;正以其多功能多场景应用的特性&#xf…

strstr的使⽤和模拟实现

strstr&#xff08;function&#xff09; Returnsa pointer to the irst occurrence of str2 in str1, or a null pointer if str2 is not part of str1. &#xff08;函数返回字符串str2在字符串str1中第⼀次出现的位置&#xff09;。 The matchingprocess doesnot include t…

无线麦克风什么品牌好?一文读懂无线领夹麦克风哪个品牌音质最好

​当我们谈论到演讲、表演或者录制视频时&#xff0c;一个高质量的无线麦克风能够使得整个体验提升至一个全新的水平。它不仅能够保证声音的清晰度和真实度&#xff0c;还能够让使用者在演讲或者表演时更加自信和舒适。基于对市场的深入研究和用户体验的考量&#xff0c;我挑选…