java生成数据库数据到excel当做下拉选择,copy就完事~

2024-04-19 12:28

本文主要是介绍java生成数据库数据到excel当做下拉选择,copy就完事~,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:由于需要下载模板,模板包含下拉选择框,但是下拉选择框不想手写,并且需要从数据库读取,由于直接设置excel会有单元格最大255个字符长度限制,所以用到以下部分代码。

思路:由于数据模板在sheet1,所以将数据库数据读取,写到sheet2里第一行第一列,然后开启数据验证,选取数据列指向sheet1的下拉列表列位置,最后隐藏sheet2页。

实现:

@Value(value = "${spring.importTemplateFileLocation}")private String importTemplateFileLocation;@GetMapping("/loadTemplateFile")
@Operation(summary = "下载项目导入模板")
public void loadTemplateFile(HttpServletResponse response) {demoService.loadTemplateFile(response);
}
 @Overridepublic void loadTemplateFile(HttpServletResponse response) {response.setContentType("application/vnd.ms-excel.sheet.macroEnabled.12");response.setCharacterEncoding("utf-8");Workbook wb = null;ServletOutputStream out = null;try (InputStream in = this.getClass().getResourceAsStream(importTemplateFileLocation)) {out = response.getOutputStream();wb = new XSSFWorkbook(in);// 获取第一个sheetSheet sheet = wb.getSheetAt(0);// 获取第二个sheetSheet sheet2 = wb.getSheetAt(1);// 获取第二个sheet的第一行第一列int auxColIndex = 0;// 获取第二个sheet的第一行第一列int auxRowIndex = 0;//查询数据库数据List<String> dataList = new ArrayList<>(););});//将下拉数据写入sheet2for (String option : dataList ) {Row auxRow = sheet2.createRow(auxRowIndex++);Cell auxCell = auxRow.createCell(auxColIndex);auxCell.setCellValue(option);}//数据验证选取范围String dataRange = new CellReference(0, auxColIndex, false, false).formatAsString() + ":" +new CellReference(leafCategoryList.size() - 1, auxColIndex, false, false).formatAsString();// 数据验证DataValidationHelper dvHelper = new XSSFDataValidationHelper((XSSFSheet) sheet);// 加载下拉列表内容DataValidationConstraint dvConstraint = dvHelper.createFormulaListConstraint("INDIRECT(\"" + sheet2.getSheetName() + "!" + dataRange + "\")");// 加载下拉列表验证区域CellRangeAddressList addressList = new CellRangeAddressList(1, 65535, 1, 1);  // 假设列 B(1, 1)// 数据有效性对象DataValidation validation = dvHelper.createValidation(dvConstraint, addressList);validation.setSuppressDropDownArrow(true);validation.setShowErrorBox(true);sheet.addValidationData(validation);List<String> programTypeList = new ArrayList<>();dictDataApi.getAllData("program_type").getData().forEach(data -> {programTypeList.add(data.getLabel() + ":" + data.getValue());});String[] programTypeArr = new String[programTypeList.size()];programTypeList.toArray(programTypeArr);ExcelUtils.setValidationData(wb.getSheetAt(0), 1, 65535, 4, 4, programTypeArr);//隐藏sheet2页wb.setSheetHidden(wb.getSheetIndex(sheet2), true);wb.write(out);} catch (Exception e) {log.error(e.toString());} finally {IOUtils.closeQuietly(wb);IOUtils.closeQuietly(out);}}

 效果:

这篇关于java生成数据库数据到excel当做下拉选择,copy就完事~的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917531

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont