SpringBoot——生成Excel文件

在Springboot以及其他的一些项目中,或许我们可能需要将数据查询出来进行生成Excel文件进行数据的展示,或者用于进行邮箱发送进行附件添加

依赖引入

此处demo使用maven依赖进行使用

<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>5.2.3</version>
</dependency>
<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>5.2.3</version>
</dependency>

依赖说明

  1. poi-ooxml:这个依赖主要用于处理 .xlsx 格式的 Excel 文件(Excel 2007 及以上版本)。它依赖于 poi 和 ooxml-schemas 等其他库,提供了对 Office Open XML 格式文件的支持。
  2. poi:这是 Apache POI 的核心库,提供了基本的 Excel 操作功能,包括创建工作簿、工作表、行和单元格等。

 代码实例

此处我们需要将用户的信息使用lis进行传输,通过遍历这个list集合进行向我们事先生成的excel文件中进行添加数据

public class ExcelGeneratorUtil {public static void generateExcel(List<Pitch> pitches) {try {//创建一个新的 Excel 工作簿对象,XSSFWorkbook 用于处理 .xlsx 格式的 Excel 文件Workbook workbook = new XSSFWorkbook();//创建一个文件输出流,用于将工作簿中的数据写入到名为 recommendedColleges.xlsx文件中FileOutputStream fileOut = new FileOutputStream("recommendedColleges.xlsx");//在工作簿中创建一个名为 Recommended Colleges 的工作表Sheet sheet = workbook.createSheet("Recommended Colleges");// 创建表头 选择第0行进行作为表头 并进行设置表头信息Row headerRow = sheet.createRow(0);Cell headerCell1 = headerRow.createCell(0);headerCell1.setCellValue("学校编号");Cell headerCell2 = headerRow.createCell(1);headerCell2.setCellValue("学校名称");Cell headerCell3 = headerRow.createCell(2);headerCell3.setCellValue("专业编号");Cell headerCell4 = headerRow.createCell(3);headerCell4.setCellValue("专业名称");Cell headerCell5 = headerRow.createCell(4);headerCell5.setCellValue("专业最低分");Cell headerCell6 = headerRow.createCell(5);headerCell6.setCellValue("专业最低位次");// 填充数据 初始化行号为 1int rowNum = 1;for (Pitch p : pitches) {//在工作表中创建新的行,并将行号加 1Row row = sheet.createRow(rowNum++);Cell cell1 = row.createCell(0);cell1.setCellValue(p.getSchoolCode());Cell cell2 = row.createCell(1);cell2.setCellValue(p.getSchoolName());Cell cell3 = row.createCell(2);cell3.setCellValue(p.getpCode());Cell cell4 = row.createCell(3);cell4.setCellValue(p.getpName());Cell cell5 = row.createCell(4);cell5.setCellValue(p.getLowestScore());Cell cell6 = row.createCell(5);cell6.setCellValue(p.getLowestRank());}//置每列的宽度,参数 1 是列索引,参数 2 是列宽,单位是 1/256 个字符宽度sheet.setColumnWidth(0, 15 * 256);sheet.setColumnWidth(1, 50 * 256);sheet.setColumnWidth(2, 15 * 256);sheet.setColumnWidth(3, 20 * 256);sheet.setColumnWidth(4, 15 * 256);sheet.setColumnWidth(5, 15 * 256);//将工作簿中的数据写入到文件输出流中,即保存到文件中workbook.write(fileOut);} catch (Exception e) {e.printStackTrace();}}
}

最终实现了excel文件的创建和使用

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

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

相关文章

mac 下 java 调用 gurobi 不能加载 jar

在 mac 电脑中的 java 始终不能加载 gurobi 的 jar 包&#xff0c;java 的开发软件 eclipse&#xff0c;idea 总是显示找不到 gurobi 的 jar 包&#xff0c;但是 jar 包明明就在那里。 摸索了三个小时&#xff0c;最后发现原因竟然是&#xff1a; jar 包太新&#xff0c;替换…

服务端配置TCP探活,超出探活时间后的行为?

server端启动 &#xff08;完整源码在最后&#xff09; 配置探活 setsockopt(client_fd, IPPROTO_TCP, TCP_KEEPIDLE, &(int){5}, sizeof(int)); // 空闲60秒后探测setsockopt(client_fd, IPPROTO_TCP, TCP_KEEPINTVL, &(int){10}, sizeof(int)); // 探测间隔10秒…

LLC谐振变换器恒压恒流双竞争闭环simulink仿真

1.模型简介 本仿真模型基于MATLAB/Simulink&#xff08;版本MATLAB 2017Ra&#xff09;软件。建议采用matlab2017 Ra及以上版本打开。&#xff08;若需要其他版本可联系代为转换&#xff09;针对全桥LLC拓扑&#xff0c;利用Matlab软件搭建模型&#xff0c;分别对轻载&#xf…

MySQL 中如何查看 SQL 的执行计划?

SQL 语句前面使用 EXPLAIN 关键字&#xff1a; EXPLAIN SELECT * FROM users WHERE id 1; 字段 含义 id 查询的序号&#xff08;如果是子查询或联合查询&#xff0c;会有多个 id&#xff09;。 select_type 查询的类型&#xff08;简单查询、子查询、联合查询等&#xff…

Discourse 中集成 Claude 3.7 Sonnet 模型

如果 Discourse 实例已经接入了 Anthropic。 那么只需要在后台挑一个不希望继续使用的模型改下就好。 否则需要重新在 Discourse 实例中配置 AI&#xff0c;然后获得 Anthropic 的 key。 进入后台的 AI 然后选择 LLMs 虽然我们这里已经显示成 3.7 了&#xff0c;但实际上所有…

Oracle 12c Docker安装问题排查 sga_target 1536M is too small

一、问题描述 在虚拟机环境&#xff08;4核16GB内存&#xff09;上部署 truevoly/oracle-12c 容器镜像时&#xff0c;一切运行正常。然而&#xff0c;当在一台 128 核 CPU 和 512GB 内存的物理服务器上运行时&#xff0c;容器启动时出现了 ORA-00821 等错误&#xff0c;提示 S…

DeepSeek 提示词:高效的提示词设计

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编…

KIMI K1.5:大规模强化学习在大语言模型中的应用与工程实践

目录 1、核心技术创新:长上下文强化学习 2、策略优化的技术细节 2.1、在线镜像下降变体 2.2、长度惩罚机制 2.3、智能采样策略 3、工程架构创新 3.1、混合部署框架 3.2、代码沙箱与奖励模型 3.3、分布式系统架构 4、实验成果与性能提升 5、结论与未来展望 大语言模…

从 0 到 1:使用 Docker 部署个人博客系统

引言 在当今数字化时代&#xff0c;拥有一个个人博客来记录自己的学习、生活和见解是一件非常有意义的事情。然而&#xff0c;传统的博客部署方式往往涉及复杂的环境配置和依赖管理&#xff0c;容易让人望而却步。而 Docker 的出现&#xff0c;为我们提供了一种简单、高效的解…

多进程网络服务端详细说明文档

多进程网络服务端详细说明文档 一、概述 本项目实现了一个基于多进程的 TCP 网络服务端&#xff0c;主要用于处理多个客户端的连接请求。为了提高代码的可维护性和可复用性&#xff0c;分成了头文件&#xff08;.h&#xff09;和多个源文件&#xff08;.cpp&#xff09;。具体…

HDFS数据多目录、异构存储、回收站

1.NameNode元数据多目录 HDFS集群中可以在hdfs-site.xml中配置“dfs.namenode.name.dir”属性来指定NameNode存储数据的目录&#xff0c;默认NameNode数据存储在${hadoop.tmp.dir}/dfs/name目录&#xff0c;“hadoop.tmp.dir”配置项在core-site.xml中。 我们也可以将NameNod…

TFChat:腾讯大模型知识引擎(DeepSeek R1)+飞书机器人实现AI智能助手

效果 TFChat项目地址 https://github.com/fish2018/TFChat 腾讯大模型知识引擎用的是DeepSeek R1&#xff0c;项目为sanic和redis实现&#xff0c;利用httpx异步处理流式响应&#xff0c;同时使用buffer来避免频繁调用飞书接口更新卡片的网络耗时。为了进一步减少网络IO消耗&…

HTML5 面试题

1. HTML5 新增了哪些重要特性&#xff1f; 语义化标签&#xff1a;这些标签有助于提高页面的可读性和可维护性。多媒体支持&#xff1a;HTML5 引入了 和 标签&#xff0c;可以直接嵌入音频和视频文件&#xff0c;无需依赖插件。本地存储&#xff1a;引入了 localStorage 和 se…

【Linux】Linux常用命令

目录 文件和目录相关命令查看和管理进程磁盘和文件系统管理用户和权限管理网络相关命令文本处理命令系统状态查看命令软件包管理命令计划任务和后台作业其他常用命令 1. 文件和目录相关命令 命令作用示例pwd显示当前工作目录pwdls列出目录内容ls -l 查看详细信息cd切换目录cd…

布署elfk-准备工作

建议申请5台机器部署elfk&#xff1a; filebeat(每台app)--> logstash(2台keepalived)--> elasticsearch(3台)--> kibana(部署es上)采集输出 处理转发 分布式存储 展示 ELK中文社区: 搜索客&#xff0c;搜索人自己的社区 官方…

DeepSeek:我的AI助手之旅

★【前言】: 初次使用AI助手帮我写作,就像摸石头过河一样,一点点的前行。我在慢慢的摸索,慢慢的体会中,感悟出的一点个人心得体会现分享给大家。这也说明一个问题,网站上各种使用方法和技巧是对于已经使用过的人来说的方便和快捷,但对于刚刚接触的使用者来说,网上的各…

esp8266 rtos sdk开发环境搭建

1. 安装必要的工具 1.1 安装 Git Git 用于从远程仓库克隆代码&#xff0c;你可以从Git 官方网站下载 Windows 版本的安装程序。安装过程中可保持默认设置&#xff0c;安装完成后&#xff0c;在命令提示符&#xff08;CMD&#xff09;或 PowerShell 中输入git --version&#…

C# | GDI+图像测距辅助线的实现思路

C# | GDI图像测距辅助线的实现思路 文章目录 C# | GDI图像测距辅助线的实现思路一、辅助线需求概述二、坐标系与角度计算2.1 笛卡尔坐标系2.2 线长和角度计算方法2.3 文本角度矫正计算方法2.4 坐标变换实现步骤 三、与if判断方式对比四、总结 一、辅助线需求概述 在图像测量工…

记录此刻:历时两月,初步实现基于FPGA的NVMe SSD固态硬盘存储控制器设计!

背景 为满足实验室横向项目需求&#xff0c;在2024年12月中下旬导师提出基于FPGA的NVMe SSD控制器研发项目。项目核心目标为&#xff1a;通过PCIe 3.0 x4接口实现单盘3000MB/s的持续读取速率。 实现过程 调研 花了半个月的时间查阅了一些使用FPGA实现NVME SSD控制器的论文、…