【Java中导出Excel导出多个sheet页】

Java中导出Excel导出多个sheet页

  • 序言
  • 如何处理多个sheet页的导出
  • 期间遇到了一个sheet页相关的问题,以及解决办法
    • 多sheet页导出遇到,第二个sheet页的标题名称会把第一个的覆盖的问题
  • 结语

序言

在日常工作中经常有导出数据文件的需求,避免不了会有导出多个sheet页的功能,这里给大家分享一个自己使用过的方法。

如何处理多个sheet页的导出

下面是导出的方法代码,用到的参数基本就是两个对应的数据集合,两个数据的标题(这个根据自己需求来,可以不用),excel文件名称,以及两个sheet页的名称。
// 这里是导出多个sheet页的方法代码/*** 导出多个sheet页* @param response* @param list 第一个sheet页数据集合* @param list1 第二个sheet页数据集合* @param title 第一个的标题* @param title1 第二个的标题* @param fileName excel文件名称* @param sheetName 第一个sheet页名* @param sheetName1 第二个sheet页名*/public static void exportExcelPlus1(HttpServletResponse response,List<?> list,List<?> list1,String title,String title1,String fileName,String sheetName,String sheetName1){if (CollUtil.isEmpty(list)) {throw new SystemNoLogException(ResponseCode.EXCEL_EXPORT_FAILED, "无数据可导出");}Class<?> clazz = list.get(0).getClass();Class<?> clazz1 = list1.get(0).getClass();if (StrUtil.isEmpty(fileName)) {fileName = "Excel导出";}try {response.setContentType("application/vnd.ms-excel");response.setCharacterEncoding("utf-8");String fileSuffix = new SimpleDateFormat("yyyyMMdd-HHmmss").format(new Date());fileName = fileName.concat("_").concat(fileSuffix);String excelName = URLEncoder.encode(fileName, "UTF-8");response.setHeader("Content-disposition", "attachment;filename=" + excelName + ExcelTypeEnum.XLSX.getValue());Field[] fields = clazz.getDeclaredFields();List<Field> fieldList = Arrays.stream(fields).filter(item -> item.getAnnotation(ExcelProperty.class) != null).collect(Collectors.toList());int cellCount = fieldList.size();ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).excelType(ExcelTypeEnum.XLSX).build();WriteSheet mainSheet = EasyExcel.writerSheet(0, sheetName).head(clazz).registerWriteHandler(new ExportExcelTitleWriteHandler(cellCount, title,0)).registerWriteHandler(new ExportExcelHeadWriteHandler(1)).registerWriteHandler(new HorizontalCellStyleStrategy(defaultHeadStyle(), defaultContentCellStyle())).sheetName(sheetName)//默认样式.useDefaultStyle(true)//写入头信息的开始行数.relativeHeadRowIndex(1).build();excelWriter.write(list,mainSheet);Field[] fields1 = clazz1.getDeclaredFields();List<Field> fieldList1 = Arrays.stream(fields1).filter(item -> item.getAnnotation(ExcelProperty.class) != null).collect(Collectors.toList());int cellCount1 = fieldList1.size();WriteSheet dSheet = EasyExcel.writerSheet(1, sheetName1).head(clazz1).registerWriteHandler(new ExportExcelTitleWriteHandler(cellCount1, title1,1)).registerWriteHandler(new ExportExcelHeadWriteHandler(1)).registerWriteHandler(new HorizontalCellStyleStrategy(defaultHeadStyle(), defaultContentCellStyle())).sheetName(sheetName1)//默认样式.useDefaultStyle(true)//写入头信息的开始行数.relativeHeadRowIndex(1).build();excelWriter.write(list1,dSheet);excelWriter.finish();} catch (Exception e) {log.error("export excel error", e);response.reset();response.setContentType("application/json");response.setCharacterEncoding("utf-8");try {String message = "下载文件失败" + e.getMessage();RestResponse restResponse = RestResponse.build(ResponseCode.EXCEL_EXPORT_FAILED, message);response.getWriter().println(JSON.toJSONString(restResponse));} catch (IOException ioException) {log.error("export excel error", ioException);throw new SystemNoLogException(ResponseCode.EXCEL_EXPORT_FAILED, ioException.getMessage());}}}

期间遇到了一个sheet页相关的问题,以及解决办法

多sheet页导出遇到,第二个sheet页的标题名称会把第一个的覆盖的问题

 导出数据之后发现,第二个的标题名称覆盖了第一个的标题,去网上找到了对应的解决办法,就是给标题赋值的时候,后面加上对应的sheet页索引,这样就能指定每一个sheet页对应的标题名称,下图中红色框中最后的索引就对应了各自的sheet页,索引从0开始,大家可以根据自己需求更改。

多sheet页相关问题

结语

不是职业博主,只是记录自己用到的一些技术点或者问题相关的解决办法,以便于以后用到的时候查看,顺便分享,如果有无法解决问题可以留言,看到会及时回复。

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

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

相关文章

工具篇:鸿蒙DevEco Studio5.0版本下载及安装

1、下载中心地址 下载中心 | 华为开发者联盟-HarmonyOS开发者官网&#xff0c;共建鸿蒙生态 2、安装 DevEco Studio支持Windows和macOS系统&#xff0c;下面将针对两种操作系统的软件安装方式分别进行介绍。 Windows环境 运行环境要求 为保证DevEco Studio正常运行&#…

电机驱动知识点总结

一、直流电机入门基础知识 1.直流电机原理 下面是分析直流电机的物理模型图。其中&#xff0c;固定部分有磁铁&#xff0c;这里称作主磁极&#xff1b;固定部分还有电刷。转动部分有环形铁心和绕在环形铁心上的绕组。(其中 2 个小圆圈是为了方便表示该位置上的导体电势或电流…

GaussDB关键技术原理:高性能(二)

GaussDB关键技术原理&#xff1a;高性能&#xff08;一&#xff09;从数据库性能优化系统概述对GaussDB的高性能技术进行了解读&#xff0c;本篇将从查询处理综述方面继续分享GaussDB的高性能技术的精彩内容。 2 查询处理综述 内容概要&#xff1a;本章节介绍查询端到端处理的…

基于STM32F103最小系统板和DL-LN33 2.4G通信 ZigBee无线串口自组网采集温湿度

文章目录 前言一、组网概述二、产品特性三、电气特性四、引脚配置五、UART通信协议5.1 UART参数5.2 包分割5.3 端口5.4 举例通信5.4.1 一个节点给另一个节点发送数据5.4.2 一个节点给另一个节点的内部端口发送数据5.4.3 一个节点给自己的内部端口发送数据5.4.4 不推荐的数据传输…

气膜体育馆的安装流程—轻空间

随着人们对健康生活和高品质运动环境的追求&#xff0c;气膜体育馆因其独特的优点而逐渐受到青睐。轻空间将详细介绍气膜体育馆的安装流程&#xff0c;从实地勘测到检测&#xff0c;再到最终的清理现场&#xff0c;每一步都至关重要&#xff0c;确保体育馆的安全性和功能性。 一…

【AI生成】海上风电中卫星网络与无线自组网的优缺点分析

在海上风电行业&#xff0c;卫星网络和无线自组网是两种重要的通信技术。本文将详细分析这两种技术的优缺点&#xff0c;以帮助读者更好地了解其在海上风电中的应用。 一、卫星网络 优点&#xff1a; 1.全球覆盖&#xff1a;卫星网络可以实现全球范围内的通信覆盖&#xff0…

git 合并多次commit,提交MR

本文参考大佬的https://blog.csdn.net/qq_46106285/article/details/130459829中的第二部分成功解决问题。 合并所有历史提交。其方法本质是删除所有的.git提交的记录&#xff0c;用原来的文件新建一个仓库做第一次提交。 方式二&#xff1a;新建本地的 git 仓库 这种方式是…

内网穿透与异地组网强强联合,这款工具屌爆了!!!

在数字化飞速发展的今天&#xff0c;远程访问的需求日益增长&#xff0c;网络已成为我们生活和工作中不可或缺的一部分。然而&#xff0c;远程网络连接的稳定性和安全性往往是我们关注的焦点。节点小宝作为一款创新型的远程管理工具&#xff0c;凭借其使用简单&#xff0c;高速…

DDL数据表操作

特别注意&#xff1a;创建数据表必须有一个前提&#xff0c;首先要明确选择某一个数据库。 1、数据表的基本操作 ☆ 数据表的创建 创建 > create 数据表 > table 创建 数据表 create table 数据表名称 基本语法&#xff1a; mysql> create table 数据表名称(…

RabbitMQ WEB管理端介绍

页面功能概览 Overview(概述)Connections(连接)Channels(通道)Exchanges(交换器)Queues(队列)Admin(用户管理)。 1. Overview(概述) 主要分为三部分 1.1 Queued messages&#xff08;所有队列的消息情况&#xff09; Ready&#xff1a;待消费的消息总数Unacked&#xff1a;待应…

实时美颜技术解析:视频美颜SDK如何改变直播行业

实时美颜技术的出现&#xff0c;尤其是视频美颜SDK的应用&#xff0c;正逐渐改变着直播行业的生态。 一、实时美颜技术的原理 实时美颜技术利用人工智能和图像处理算法&#xff0c;对视频中的人物面部进行优化和修饰。该技术通常包含以下几个步骤&#xff1a; 1.人脸检测和识…

OpenGL->OpenGL环境搭建和配置

OpenGL概述 OpenGL&#xff1a;用于渲染2D、3D矢量图形的APIGLEW&#xff1a;是一个跨平台的C/C库&#xff0c;能够使用更高版本的OpenGL扩展特性GLFW&#xff1a;创建和管理OpenGL上下文&#xff0c;管理渲染窗口&#xff0c;处理输入事件&#xff0c;更轻量GLUT&#xff1a;…

视频格式转换方法:如何使用视频转换器软件转换视频

众所周知&#xff0c;目前存在许多不同的视频和音频格式。但我们的媒体播放器、移动设备、PC 程序等仅兼容少数特定格式。例如&#xff0c;如果不先将其转换为 MP4、MOV 或 M4V 文件&#xff0c;AVI、WMV 或 MKV 文件就无法在 iPhone 上播放。 视频转换器允许您将一种视频格式…

Qt,python获取IP地址信息

文章目录 1.python获取IP地址信息2.Qt获取IP地址信息3.带界面的,基于QML步骤1:创建QML界面步骤2:创建C++类处理网络请求步骤3:将C++类与QML绑定步骤4:构建和运行总结参考1.python获取IP地址信息 通过公开接口批量查询IP地址归属地 """ @Author:pandasgb …

解决微信小程序使用textarea输入框 type=“textarea“ 文本输入限制问题

出现的问题 type"textarea" 这个限制 微信小程序使用textarea , 输入字数大于140 时就输入不进去了 加入这个就解决了 maxlength"-1" <u-inputv-model"queryParams.orderIdTxt"border"true":focus"true":auto-height&q…

makefile学习过程

makefile 完美教程 - WittXie - 博客园 (cnblogs.com) Makefile教程&#xff08;绝对经典&#xff0c;所有问题看这一篇足够了&#xff09;-CSDN博客 Makefile入门(超详细一文读懂)-CSDN博客 最实用的Makefile教程 真的很简单&#xff08;搞不明白网上的教程写那么复杂干嘛&…

【知识学习】阐述Unity3D中Stencil的概念及使用方法示例

在Unity3D中&#xff0c;Stencil&#xff08;模板&#xff09;是一种高级的图形渲染技术&#xff0c;它允许开发者对渲染过程进行精细控制。Stencil Buffer是附加在颜色缓冲区和深度缓冲区之外的另一个缓冲区&#xff0c;它可以用来存储每个像素是否应该被渲染的信息。 Stenci…

自动化物流控制系统WCS应用与异常处理

导语 大家好&#xff0c;我是社长&#xff0c;老K。专注分享智能制造和智能仓储物流等内容。 新书《智能物流系统构成与技术实践》人俱乐部 完整版文件和更多学习资料&#xff0c;请球友到知识星球【智能仓储物流技术研习社】自行下载 WCS的定义与作用&#xff1a; 物流仓储设备…

探索AIGC治愈系创作:Stable Diffusion 带你轻松复刻某书爆款动漫卡通文案!

hello&#xff0c;大家好我是安琪&#xff01; 情感治愈类一直是受众群体很高非常火爆的赛道&#xff0c;安琪也关注到在某书平台上&#xff0c;漫画治愈类风格的内容也是非常的受欢迎。先来看看以下一些案例 看看这几个账号内容的质量就可以看出该部分内容是很受欢迎的&#x…

go get 和 go mod tidy 的区别

go get 和 go mod tidy 的效果很相近&#xff0c;它们都可以下载需要的依赖项并更新 go.mod 和 go sum 所以在使用时经常会发生混淆。其实它们最主要区别就在于 go mod tidy 能在我们从代码中移除某个依赖之后&#xff0c;重新整理 go.mod 和 go.sum 文件&#xff0c;比如我们在…