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

导出Excel,支持最佳

列表信息导出为Excel文件,

依赖pom:

Sheet, Row:<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId>
</dependency>XSSFWorkbook
<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId>
</dependency>
实现代码: 

override表示是否覆盖现有文件,false,追加;true,覆盖。

private <T> void exportExcelToLocal(List<T> list, Class<T> clazz) throws IOException {if (CollectionUtils.isEmpty(list)) {return;}XSSFWorkbook workbook = null;File file = new File("src/main/resources/xxx.xlsx");FileInputStream fis = null;if (!file.exists()) {file.createNewFile();} else {if (!override) {fis = new FileInputStream(file);workbook = new XSSFWorkbook(fis);}}XSSFWorkbook workbookResult = ExcelUtils.exportExcelData(new XSSFWorkbook(), list, clazz, false);if (Objects.nonNull(workbook)) {Integer index = workbookResult.getSheetAt(0).getLastRowNum() + 1;Sheet sheet = workbookResult.getSheetAt(0);Sheet lastSheet = workbook.getSheetAt(0);for (int i = 1; i <= lastSheet.getLastRowNum(); ++i) {Row row = sheet.createRow(index++);for (int cellIndex = 0; cellIndex < lastSheet.getRow(i).getLastCellNum(); ++cellIndex) {String value = lastSheet.getRow(i).getCell(cellIndex).getStringCellValue();row.createCell(cellIndex).setCellValue(value);}}}FileOutputStream fos = new FileOutputStream(file);workbookResult.write(fos);fos.flush();fos.close();if (Objects.nonNull(fis)) {fis.close();}}

ExcelUtils:

单次导出操作

public static <T> XSSFWorkbook exportExcelData(XSSFWorkbook workbook, List<T> data, Class<T> clazz, boolean template) {XSSFSheet sheet = workbook.createSheet();Row rowHeader = sheet.createRow(0);Map<Integer, Field> fieldMap = analysisAnnotation(clazz);for(int i = 0; i < fieldMap.size(); ++i) {Cell cell = rowHeader.createCell(i);Field field = (Field)fieldMap.get(i + 1);ExcelBind ea = (ExcelBind)field.getAnnotation(ExcelBind.class);cell.setCellValue(ea.columnName());cell.setCellStyle(setRowHeaderStyle(workbook));cell.setCellType(CellType.STRING);}if (!template) {analysisData(sheet, data, clazz, fieldMap);}return workbook;}// 数据导出
private static <T> void analysisData(Sheet sheet, List<T> data, Class<T> clazz, Map<Integer, Field> fieldMap) {for(int i = 0; i < data.size(); ++i) {Row row = sheet.createRow(i + 1);T t = data.get(i);Class<?> aClass = t.getClass();for(int j = 0; j < fieldMap.size(); ++j) {Field declaredField = (Field)fieldMap.get(j + 1);declaredField.setAccessible(true);String key = declaredField.getName();Object value = "";try {value = declaredField.get(t) == null ? "" : declaredField.get(t);} catch (IllegalAccessException var13) {var13.printStackTrace();}if ("java.util.Date".equals(declaredField.getType().getName())) {ExcelBind ea = (ExcelBind)declaredField.getAnnotation(ExcelBind.class);if (StringUtils.isNotEmpty(ea.dateFormat())) {value = (new SimpleDateFormat(ea.dateFormat())).format(value);}}row.createCell(j).setCellValue(value.toString());}}}

相关文章:

导出Excel,支持最佳

列表信息导出为Excel文件&#xff0c; 依赖pom&#xff1a; Sheet, Row:<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId> </dependency>XSSFWorkbook <dependency><groupId>org.apache.poi</…...

【WPF】获取父控件数据

MaxHeight"{Binding PathActualHeight, RelativeSource{RelativeSource ModeFindAncestor, AncestorTypeUserControl}}" 参考文献 https://www.cnblogs.com/-Timosthetic/p/16021865.html...

解决Edge浏览器,微博无法查看大图(Edge Image Viewer)

使用Edge浏览器浏览微博或其它带校验的图片时&#xff0c;会导致无法查看。 主要原因为Edge自带了一个Edge Image Viewer, 但是该图片查看器无法查看带校验数据的图片&#xff0c;所以导致查看时一片空白。 解决方法 地址栏输入 edge://flags/搜索 Edge Image Viewer选择 Disa…...

PMP含金量在国内怎么样?

其一、PMP(项目管理师)证书含金量高吗&#xff1f; PMP认证是由美国项目管理学会(PMI)在全球范围内推出的针对项目经理的资格认证体系&#xff0c;其证书含金量可以说是非常高。 统计表明&#xff0c;全球年销售收入在5亿美元以上的企业中有86%聘用了具有项目管理资质的项目经…...

java中容易被忽视的toString()方法

之前一直认为toString就是将数据转换成字符类型&#xff0c;直到最近写出了一个bug才对toString有了新的认识 不同数据类型&#xff0c;toString() 有不同的操作 定义一个student类&#xff0c;包含姓名 String类型、性别 String类型、年龄 int 类型、分数列表 String类型的li…...

如何使用Docker搭建YesPlayMusic网易云音乐播放器并发布至公网访问

文章目录 1. 安装Docker2. 本地安装部署YesPlayMusic3. 安装cpolar内网穿透4. 固定YesPlayMusic公网地址 本篇文章讲解如何使用Docker搭建YesPlayMusic网易云音乐播放器&#xff0c;并且结合cpolar内网穿透实现公网访问音乐播放器。 YesPlayMusic是一款优秀的个人音乐播放器&am…...

java面试题之redis篇

1.redis 中的数据类型有哪些 随着 Redis 版本的更新&#xff0c;后面又支持了四种数据类型&#xff1a; BitMap&#xff08;2.2 版新增&#xff09;、HyperLogLog&#xff08;2.8 版新增&#xff09;、GEO&#xff08;3.2 版新增&#xff09;、Stream&#xff08;5.0 版新增&am…...

effective c++ 笔记 条款18-25

条款18&#xff1a;让接口容易被正确使用&#xff0c;不易误使用 使用外覆类型&#xff08;wrapper&#xff09;提醒调用者传参错误检查&#xff0c;将参数的附加条件限制在类型本身 Data::Data(int month, int day, int year) { ... }三个参数类型相同的函数容易造成误用 Da…...

Nginx学习笔记

Bilibili尚硅谷视频 Nginx 简介 Nginx 概述 Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理服务器&#xff0c;特点是占有内存少&#xff0c;并发能力强&#xff0c;能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数 。 正向代理 正向代理&#xff1a;如…...

摆(行列式、杜教筛)

有一个 n n n\times n nn 的矩阵 A A A&#xff0c;满足&#xff1a; A i , j { 1 i j 0 i ̸ j ∧ i ∣ j C otherwise A_{i,j}\begin{cases} 1 &ij\\ 0 &i\notj\land i\mid j\\ C &\text{otherwise} \end{cases} Ai,j​⎩ ⎨ ⎧​10C​ijij∧i∣jotherwi…...

尝试以语法对照表格形式学习新语言:c,rust

以语法对照表格形式学习新语言&#xff0c;以rust为例。 关于rust的个人看法&#xff1a; 能否替代c&#xff1f;部分场景可以&#xff0c;长远看并不会。如果c再扩一些关键字&#xff0c;类似cpp的吸星大法式扩充&#xff0c;rust并不具备优势。解决了c的内存管理问题&#x…...

408计算机网络--基础概论

学习计算机网络走以前需要首先明白一个大的概念&#xff0c;计算机网络通常分为通信子网&#xff08;实现数据通信&#xff09;和资源子网&#xff08;实现资源共享/数据处理&#xff09;七层妖塔 计算机网络&#xff1a;是一个将分散的、具有独立功能的计算机系统&#xff0…...

数据库应用:kylin 部署 达梦数据库DM8

目录 一、实验 1.环境 2.部署前规划 3.部署达梦数据库DM8 4.创建数据库及数据库事例管理 5.达梦数据库的基本操作 二、问题 1.xhost命令报错 2.执行安装程序DMInstall.bin 报错 3.解压安装程序报错 4.安装程序找不到文件 5.图像化界面打不开 6.安装内存太小 7.打开…...

GO框架基础 (二)、sqlx库

在 Go 语言中&#xff0c;sqlx 包是一个用于数据库操作的库&#xff0c;它建立在标准库的 database/sql 包之上&#xff0c;并提供了一些额外的功能&#xff0c;以简化和增强与数据库的交互。sqlx 的目标是通过提供更方便的 API 和一些附加功能来改善在 Go 中进行 SQL 数据库查…...

Expected class selector “.menuChildMall“ to be kebab-case报错原因

![在这里插入图片描述](https://img-blog.csdnimg.cn/dire ct/6b72bda760a2497a90558d48bd0a4de3.png) 使用stylelint格式化css文件时候报上述错误&#xff1a; 原因&#xff1a; css类名未使用-分隔符 将类名修改为&#xff1a; .menu-child-mall形式即可...

NC文件不规则裁剪(利用shp文件裁剪)(三)

文章目录 前言实例数据代码部分需要的库加载文件写入地理信息裁剪NC结果 完整代码奉上 前言 Hello大家好呀&#xff0c;最近正好需要用到多个SHP去裁剪NC&#xff0c;按照我以前的两种办法&#xff08;办法1和办法2&#xff09;操作的话&#xff0c;我自己都会破防&#xff0c…...

java 宠物在线商城系统Myeclipse开发mysql数据库web结构jsp编程servlet计算机网页项目

一、源码特点 java 宠物在线商城系统是一套完善的java web信息管理系统 servletdaobean mvc模式&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S 模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&…...

三防平板丨手持工业平板丨ONERugged工业三防平板丨推动数字化转型

随着科技的发展&#xff0c;数字化转型已经成为企业转型升级的必由之路。而在数字化转型中&#xff0c;三防平板作为一种重要的工具&#xff0c;可以极大地推动企业的数字化转型。本文将从以下几个方面探讨三防平板如何推动数字化转型。 一、提高工作效率 ONERugged加固平板的…...

【Linux | C++ 】基于环形队列的多生产者多消费者模型(Linux系统下C++ 代码模拟实现)

阅读导航 引言一、生产者消费者模型二、环形队列简介三、基于环形队列的生产者消费者模型&#xff08;C 代码模拟实现&#xff09;⭕Makefile文件⭕ . h 头文件✅sem.hpp✅ringQueue.hpp ⭕ . cpp 文件✅testMain.cpp 温馨提示 引言 在上一篇文章中&#xff0c;我们深入探讨了…...

【Docker】Docker存储卷

文章目录 一、什么是存储卷二、为什么需要存储卷三、存储卷分类四、管理卷Volume创建卷方式一&#xff1a;Volume 命令操作方式二&#xff1a;-v 或者--mount 指定方式三&#xff1a;Dockerfile 匿名卷 操作案例Docker 命令创建管理卷Docker -v 创建管理卷Docker mount 创建管理…...

【SpringBoot 3.x 第202节】微服务拆分方法论:什么时候该拆,什么时候不该拆?

&#x1f3c6;本文收录于《滚雪球学SpringBoot 3.x》&#xff0c;专门攻坚指数提升&#xff0c;本年度国内最系统最专业最详细&#xff08;永久更新&#xff09;。    该专栏致力打造最硬核 SpringBoot3 从零基础到进阶系列学习内容&#xff0c;&#x1f680;均为全网独家首发…...

Mythos模型:AI安全能力跃迁与红队自动化新范式

1. 这不是一次普通模型发布&#xff1a;Mythos背后的真实技术分水岭“Claude Mythos Preview”这七个字&#xff0c;最近在安全圈和AI工程一线引发的震动&#xff0c;远超多数人最初预估。它不是又一个参数堆叠的“更大模型”&#xff0c;也不是一次常规的SOTA刷新——它是一次…...

抖音下载神器:3步轻松搞定无水印批量下载完整教程

抖音下载神器&#xff1a;3步轻松搞定无水印批量下载完整教程 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. …...

5分钟实现OBS多平台同步直播:obs-multi-rtmp插件完全指南

5分钟实现OBS多平台同步直播&#xff1a;obs-multi-rtmp插件完全指南 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp 你是否厌倦了在不同直播平台间来回切换的繁琐操作&#xff1f;obs-…...

从‘微软 ORG’到流畅中文NLP:你的zh_core_web_sm模型真的装对了吗?

从‘微软 ORG’到流畅中文NLP&#xff1a;你的zh_core_web_sm模型真的装对了吗&#xff1f; 当你在Spacy中加载zh_core_web_sm模型&#xff0c;运行示例文本"微软准备用十亿美金买下这家英国的创业公司"后&#xff0c;看到"微软"被正确标记为ORG&#xff0…...

如何用MusicFree插件构建你的跨平台音乐生态:从零开始的全流程指南

如何用MusicFree插件构建你的跨平台音乐生态&#xff1a;从零开始的全流程指南 【免费下载链接】MusicFreePlugins MusicFree播放插件 项目地址: https://gitcode.com/gh_mirrors/mu/MusicFreePlugins 厌倦了在不同音乐应用间反复切换&#xff1f;MusicFree插件系统为你…...

效率优化:把网申填表交给塔塔网申的简历代投,省下时间刷题

招聘季一到&#xff0c;后台一堆私信。本以为大家会问算法题、系统设计&#xff0c;结果点开一看——全在骂网申填表。有个读者给我算了一笔账&#xff1a;投了30家公司&#xff0c;每家填20分钟&#xff0c;就是10个小时。10个小时能干嘛&#xff1f;刷好几套LeetCode&#xf…...

PC版微信小程序抓包实战:WinHTTP+Proxifier+Burp精准拦截方案

1. 为什么PC版微信小程序抓包非得绕开模拟器&#xff1f;很多人一提“抓PC微信小程序的包”&#xff0c;第一反应就是开个安卓模拟器&#xff0c;装个微信PC版的APK&#xff0c;再配个Fiddler或者Charles——这路子没错&#xff0c;但实操起来全是坑。我去年帮三个客户做小程序…...

手把手用Python实现μ律/A律压缩算法(附完整代码与波形对比)

手把手用Python实现μ律/A律压缩算法&#xff08;附完整代码与波形对比&#xff09; 在数字音频处理领域&#xff0c;动态范围压缩是一个永恒的话题。想象一下&#xff0c;当你录制一段包含轻柔耳语和强烈鼓声的音频时&#xff0c;直接使用线性PCM编码会导致要么小声部分被量化…...

Triangle Splatting:可微分渲染中的三角形基元优化技术

1. Triangle Splatting&#xff1a;可微分渲染中的三角形基元革命在计算机图形学领域&#xff0c;三角形作为最基础的几何基元&#xff0c;长期以来一直是实时渲染管线的核心支柱。这种简单而强大的几何单元能够高效地表示复杂表面&#xff0c;得益于GPU硬件中专门的三角形处理…...