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

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

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

实现:

java 复制代码
@Value(value = "${spring.importTemplateFileLocation}")
    private String importTemplateFileLocation;

@GetMapping("/loadTemplateFile")
@Operation(summary = "下载项目导入模板")
public void loadTemplateFile(HttpServletResponse response) {
    demoService.loadTemplateFile(response);
}
java 复制代码
 @Override
    public 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);
            // 获取第一个sheet
            Sheet sheet = wb.getSheetAt(0);
            // 获取第二个sheet
            Sheet sheet2 = wb.getSheetAt(1);

            // 获取第二个sheet的第一行第一列
            int auxColIndex = 0;
            // 获取第二个sheet的第一行第一列
            int auxRowIndex = 0;

            //查询数据库数据
            List<String> dataList = new ArrayList<>(););
            });
            //将下拉数据写入sheet2
            for (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);
        }
    }

效果:

相关推荐
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble5 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟5 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖5 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_12498707536 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_6 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.6 小时前
Day06——权限认证-项目集成
java
瑶山6 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy7 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
2301_818732067 小时前
前端调用控制层接口,进不去,报错415,类型不匹配
java·spring boot·spring·tomcat·intellij-idea