当前位置: 首页 > news >正文

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("专业最低位次");

            // 填充数据 初始化行号为 1
            int rowNum = 1;
            for (Pitch p : pitches) {
                //在工作表中创建新的行,并将行号加 1
                Row 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文件的创建和使用

相关文章:

  • 基于 C++ Qt 的 Fluent Design 组件库 QFluentWidgets
  • python-文件系统(1)
  • 设计模式的引入
  • C语言 第一章(3)
  • NLP学习记录十:多头注意力
  • 二叉树中的深搜(典型算法思想)—— OJ例题算法解析思路
  • Python入门13:Python闭包与装饰器
  • 渗透测试(WAF过滤information_schema库的绕过,sqllib-46关,海洋cms9版本的注入)
  • Discourse 中集成 Claude 3.7 Sonnet 模型
  • AutoMQ 可观测性实践:如何使用 OpenTelemetry 监控 Kafka 和底层流存储
  • 从“Switch-case“到“智能模式“:C#模式匹配的终极进化指南
  • Vue 2 新手入门指南
  • 如何在docker上部署前端nginx服务(VUE)
  • dex2oat配置方法及优化指南
  • 【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
  • 关于在java项目部署过程MySQL拒绝连接的分析和解决方法
  • ubuntu上boost卸载和安装
  • 大模型自动提示优化(APO)综述笔记
  • Win10开启电脑自带录屏截图功能
  • 学Java第三十一天----------多态调用成员的特点
  • 戴维·珀杜宣誓就任美国驻华大使
  • 明天起,沪苏湖高铁、杭温高铁推出13款新型票制产品
  • 国家矿山安全监察局发布《煤矿瓦斯防治能力评估办法》
  • 世界人形机器人运动会将在北京“双奥场馆”举行
  • 同观·德国|默茨当总理后,能否带领德国在欧盟“说了算”?
  • 潘功胜:央行将创设科技创新债券风险分担工具