导出excle表

文章目录

  • 导出excle表
    • 需求场景
    • 引入依赖
    • 具体代码

导出excle表

需求场景

假设我们有一个需求,现在数据库中有一些用户信息,我们想要把这些信息导出到excle表格中,然后存储到本地磁盘中。要求:excle表格的第一行需要有黄色背景,然后单元格文字居中,正文的所有行高度和宽度都是自适应。

引入依赖

关键依赖是下面这三个,如下图:
在这里插入图片描述
不过需要注意的是必须要和引入的spring-boot-starter-web依赖互相匹配,如下图:
在这里插入图片描述
全部代码如下:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>validated</artifactId><version>1.0-SNAPSHOT</version><packaging>jar</packaging><name>validated</name><url>http://maven.apache.org</url><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><dependencies><!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>2.1.4.RELEASE</version></dependency><!-- https://mvnrepository.com/artifact/org.hibernate.validator/hibernate-validator --><dependency><groupId>org.hibernate.validator</groupId><artifactId>hibernate-validator</artifactId><version>6.1.7.Final</version></dependency><!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version></dependency><!--easy-poi--><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>4.1.0</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-web</artifactId><version>4.1.0</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-annotation</artifactId><version>4.1.0</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>1.7.16</version></dependency><dependency><groupId>org.jetbrains</groupId><artifactId>annotations-java5</artifactId><version>RELEASE</version><scope>compile</scope></dependency></dependencies>
</project>

具体代码

首先我们写一个User导出excle的类,注意需要通过@Excle属性指定excle的列名以及每列的顺序,如下图:
在这里插入图片描述
第一列是姓名,第二列是密码,第三列是性别,第四列是住址;

接着看一下具体的导出代码,如下:

package org.example.excel;import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams;
import cn.afterturn.easypoi.excel.entity.enmus.ExcelType;
import org.apache.poi.ss.usermodel.*;import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;public class ExportExcelExample {public static void main(String[] args) throws IOException {// 创建数据列表List<User> userList = new ArrayList<User>();userList.add(new User("张三", "123456", "男", "北京市朝阳区"));userList.add(new User("李四", "abcdef", "女", "上海市浦东新区"));// 设置导出参数ExportParams exportParams = new ExportParams();exportParams.setSheetName("Sheet1"); // 设置工作表名称exportParams.setType(ExcelType.XSSF); // 设置Excel类型为xlsx// 导出ExcelWorkbook workbook = ExcelExportUtil.exportExcel(exportParams, User.class, userList);//创建黄色背景样式CellStyle yellowBackground = workbook.createCellStyle();yellowBackground.setFillForegroundColor(IndexedColors.YELLOW.getIndex());yellowBackground.setFillPattern(FillPatternType.SOLID_FOREGROUND);// 将两个样式合并到一个新的样式中CellStyle combinedStyle = workbook.createCellStyle();combinedStyle.cloneStyleFrom(yellowBackground);//集合居中样式combinedStyle.setAlignment(HorizontalAlignment.CENTER);// 设置第一行背景颜色为黄色,单元格字体居中Sheet sheet = workbook.getSheetAt(0);Row row = sheet.getRow(0);for (int i = 0; i < row.getLastCellNum(); i++) {// 应用新的样式到单元格,把第一行的背景颜色设置为黄色,并且内容设置居中row.getCell(i).setCellStyle(combinedStyle);}// 自适应列宽和行高for (int i = 1; i < sheet.getPhysicalNumberOfRows(); i++) {Row currentRow = sheet.getRow(i);if (currentRow != null) {currentRow.setHeight((short) -1); // 自动调整行高for (int j = 0; j < currentRow.getPhysicalNumberOfCells(); j++) {Cell cell = currentRow.getCell(j);if (cell != null) {int columnWidth = sheet.getColumnWidth(j);int contentLength = cell.toString().getBytes().length;columnWidth = Math.max(columnWidth, contentLength * 256);sheet.setColumnWidth(j, columnWidth);}}}}// 保存到文件try {FileOutputStream fileOut = new FileOutputStream("D:/用户信息.xlsx");workbook.write(fileOut);} catch (Exception e) {e.printStackTrace();}// 关闭工作簿workbook.close();}
}

几个关键地方如下图:

首先是ExportParams导出参数的设置
在这里插入图片描述
这里是设置我们工作表的名字为Sheet1,效果如下图:
在这里插入图片描述

具体的导出结果会存放到WorkBook类中
看下我们导出数据到excle的工具方法,如下图:
在这里插入图片描述
ExcelExportUtil.exportExcel工具方法可以把数据导出到excel中,它有三个参数,第一个参数是“导出参数类”,第二个参数是导出列对应的类User,第三个参数就是具体的导出数据集合;

最后会得到一个Workbook类,这个类中存储着我们所有的导出数据,就相当于是一个excel文件的工作簿;

其实到这里我们就已经完成了把数据导出到excel表中的操作,但是我们有时候需要给excel表设置样式,因此就有了下面的操作;

首行设置黄色背景、单元格字体居中;正文所有行高度宽度自适应
首先来看下首行设置黄色背景、单元格字体居中,如下图:
在这里插入图片描述
接着再来看下正文所有行高度宽度自适应,如下图:
在这里插入图片描述

最后一步:通过输出流把excel导出到具体的磁盘位置;然后关闭Workbook工作簿释放资源
如下图:
在这里插入图片描述
看一下导出结果,如下图:
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

2千泰中英泰语词汇对照含MP3真人读音

越来越多的人到泰国旅游&#xff0c;今天这一份数据就是服务于此&#xff0c;包含了2000条泰语的日常生活词汇&#xff0c;并且每条记录都含有真人发音MP3对应。 有分100个章节&#xff0c;每个章节共有20条记录&#xff0c;非常适合一章节一章节的学习&#xff0c;具体章节有&…

《大数据分析》期末考试整理

一、单项选择题&#xff08;1*9&#xff09; 1.大数据发展历程&#xff1a;出现阶段、热门阶段和应用阶段 P2 2.大数据影响 P3 1&#xff09;大数据对科学活动的影响 2&#xff09;大数据对思维方式的影响 3&#xff09;大数据对社会发展的影响 4&#xff09;大数…

C语言适不适合新手学习?

C 语言&#xff0c;尽管从整体上看相对较为简单&#xff0c;但在实际编写 C 程序的过程中&#xff0c;会涉及到诸如指针等一些细节方面&#xff0c;这确实可能会给新手带来一定程度的困扰和挑战。不过&#xff0c;我们需要明确的是&#xff0c;这种挑战从某种意义上来说是具有积…

paddleocr实验过程

切割数据 Paddleocr/PPOCRLabel/gen_ocr_train_val_test.py&#xff1b;切割后的数据在train_data中&#xff0c;注意切割后的数据前缀默认是当前目录&#xff0c;因此建议切割数据在liunx中进行。建议在liunx中指定 python gen_ocr_train_val_test.py --datasetRootPathXX …

锁存器的工作原理及其在FPGA设计中的注意事项

锁存器&#xff08;Latch&#xff09;是数字电子中常用的一种基本元件&#xff0c;用于在特定的时间点或条件下“锁存”或保存输入的数据值。锁存器对脉冲电平敏感&#xff0c;它只在输入脉冲的高电平&#xff08;或低电平&#xff09;期间对输入信号敏感并改变状态。在数字电路…

vba学习系列(5)--指定区域指定字符串计数

系列文章目录 文章目录 系列文章目录前言一、需求背景二、vba自定义函数1.引入库 总结 前言 一、需求背景 想知道所有客诉项目里面什么项目最多&#xff0c;出现过多少次。 二、vba自定义函数 1.引入库 引用&#xff1a; CountCharInRange(区域,“字符串”) Function CountCh…

人有时候不逼自己一把,永远不知道自己有多牛逼!

大家好&#xff0c;我是墨云&#xff0c;一位看起来不像搞技术的IT男。 之前写过一篇文章&#xff0c;从零开始&#xff0c;如何在3个月内吸引3500用户&#xff1a;我的私域运营秘诀&#xff0c;现如今&#xff0c;我们的私域社群成员数已逾五千人。&#x1f46b; 今天的主题&a…

【漏洞复现】红海云eHR PtFjk.mob 任意文件上传漏洞

免责声明&#xff1a; 本文内容旨在提供有关特定漏洞或安全漏洞的信息&#xff0c;以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步&#xff0c;并非出于任何恶意目的。阅读者应该明白&#xff0c;在利用本文提到的漏洞信息或进行相关测…

【图解IO与Netty系列】Netty编解码器、TCP粘包拆包问题处理、Netty心跳检测机制

Netty编解码器、TCP粘包拆包问题处理、Netty心跳检测机制 Netty编解码器编码器解码器编解码器Netty提供的现成编解码器 TCP粘包拆包问题处理Netty心跳检测机制 Netty编解码器 网络传输是以字节流的形式传输的&#xff0c;而我们的应用程序一般不会直接对字节流进行处理&#x…

System-Verilog 实现DE2-115 流水灯

文章目录 一、什么是SystemVerilog二、代码实现实现结果 一、什么是SystemVerilog SystemVerilog是一种硬件描述语言(HDL)&#xff0c;它用于设计和验证电子系统&#xff0c;特别是在集成电路(IC)和系统级芯片(SoC)的设计过程中。SystemVerilog是Verilog语言的一个超集&#xf…

大模型生成的常见Top-k、Top-p、Temperature参数

参考&#xff1a; https://zhuanlan.zhihu.com/p/669661536 topK&#xff0c;topP https://www.douyin.com/video/7380126984573127945 主要是softmax产生的词表每个词的概率分布后&#xff0c; topK&#xff0c;比如K3&#xff0c;表示采样概率最大的前3个&#xff0c;其他全…

【Perl】与【Excel】

引言 perl脚本语言对于文本的处理、转换很强大。对于一些信息量庞大的文本文件&#xff0c;看起来不直观&#xff0c;可以将信息提取至excel表格中&#xff0c;增加数据分析的可视化。perl语言的cpan提供了大量模块。对于excel文件的操作主要用到模块&#xff1a; Spreadshee…

【论文速读,找找启发点】2024/6/16

ICME 2023 End-To-End Part-Level Action Parsing With Transformer 类似 DETR&#xff0c;通过 加 query的方式实现 端到端 ELAN: Enhancing Temporal Action Detection with Location Awareness 如何实现位置感知&#xff1f; > 重叠的卷积核&#xff1f; Do we really …

大数据开发流程解析

大数据开发是一个复杂且系统的过程&#xff0c;涉及需求分析、数据探查、指标管理、模型设计、ETL开发、数据验证、任务调度以及上线管理等多个阶段。本文将详细介绍每个阶段的内容&#xff0c;并提供相关示例和代码示例&#xff0c;帮助理解和实施大数据开发流程。 本文中的示…

基于WPF技术的换热站智能监控系统02--标题栏实现

1、布局划分 2、准备图片资源 3、界面UI控件 4、窗体拖动和关闭 5、运行效果 走过路过不要错过&#xff0c;点赞关注收藏又圈粉&#xff0c;共同致富&#xff0c;为财务自由作出贡献

CodeQL从入门到入土

为什么在现在写这文章 CodeQL传闻找到了Log4j的漏洞&#xff0c;这段时间上边要求&#xff0c;把公司系统内部常见的问题用CodeQL写检测脚本&#xff0c;用于系统长期检测。主要是记录这段时间的学习&#xff0c;以及自己总结的常用写法。 一个需求&#xff0c;不同人写出来的…

【Go语言】Gin 框架教程

Gin 框架教程 1.第一个 Gin 程序 1.1 Gin 安装 # 执行执行如下操作即可&#xff0c;安装Gin前需要安装Go环境 go get -u -v github.com/gin-gonic/gin # -v&#xff1a;打印出被构建的代码包的名字 # -u&#xff1a;已存在相关的代码包&#xff0c;强行更新代码包及其依赖包…

框架的使用

什么是框架&#xff1f; 盖房子&#xff0c;框架结构 框架结构就是房子主体&#xff0c;基本功能 把很多基础功能已经实现&#xff08;封装了&#xff09; 框架&#xff1a;在基础语言之上&#xff0c;对各种基础功能进行封装&#xff0c;方便开发者&#xff0c;提高开发效…

JavaFX 图像视图

JavaFX ImageView 控件可以在 JavaFX GUI 中显示图像。ImageView 控件必须添加到场景图中才能可见。JavaFX ImageView 控件由类表示 javafx.scene.image.ImageView。 创建一个 ImageView 通过创建类的实例来创建 ImageView 控件实例ImageView。类的构造函数ImageView需要一个…

02 设计过程概述

02 设计过程概述 2-1 设计需求2-2 飞机设计的各个阶段2-2-1 概念设计2-2-2 初步设计2-2-3 详细设计 2-3 飞机概念设计的流程2-4 集成产品开发和飞机设计2-5 补充2-5-1 布局设计&#xff08;Configuration Design&#xff09;关键任务&#xff1a;作用和重要性&#xff1a;使用领…