java excel xlsx 增加数据验证

隐藏表下拉框

bash 复制代码
   // 创建隐藏工作表存储下拉框数据
            String hiddenSheetName = "HiddenSheet"+System.currentTimeMillis();
            Sheet hiddenSheet =  workbook.createSheet(hiddenSheetName);
            //设置隐藏sheet
            workbook.setSheetHidden(workbook.getSheetIndex(hiddenSheetName), true);
            for (int i = 0; i < dropdownList.size(); i++) {
                Row row = hiddenSheet.createRow(i);
                Cell cityCellHidden = row.createCell(0);
                cityCellHidden.setCellValue(dropdownList.get(i));
            }
            // 获取DataValidationHelper对象
            DataValidationHelper helper = mainSheet.getDataValidationHelper();
            // 定义数据验证的范围
            CellRangeAddressList addressList = new CellRangeAddressList(startRow,  65535, columnIndex, columnIndex);
            // 创建数据验证约束 公式可以写成"Sheet2!$A$1:$A$10"。
            DataValidationConstraint constraint = helper.createFormulaListConstraint(hiddenSheetName+"!$A$1:$A$"+dropdownList.size());
            //生成验证规则
            DataValidation validation = helper.createValidation(constraint, addressList);
            // 设置错误提示信息
            validation.setShowErrorBox(true);
            validation.setSuppressDropDownArrow(true);

下拉框

bash 复制代码
   DataValidationHelper helper = mainSheet.getDataValidationHelper();
            DataValidationConstraint constraint = helper.createExplicitListConstraint(
                    dropdownList.toArray(new String[0]));
            CellRangeAddressList addressList = new CellRangeAddressList(startRow, 65535, columnIndex, columnIndex);
            DataValidation validation = helper.createValidation(constraint, addressList);
            validation.setShowErrorBox(true);
            validation.setSuppressDropDownArrow(true);
            mainSheet.addValidationData(validation);

时间格式及范围验证

bash 复制代码
       // 创建数据验证助手
        DataValidationHelper helper = sheet.getDataValidationHelper();
        CellRangeAddressList dateAddressList = new CellRangeAddressList(firstRow, lastRow, columnIndex, columnIndex);
        // 获取 LocalDateTime 的最小值
        LocalDateTime minLocalDateTime = LocalDateTime.MIN;
        // 获取 LocalDateTime 的最大值
        LocalDateTime maxLocalDateTime = LocalDateTime.MAX;
        DataValidationConstraint dataValidationConstraint = helper.createDateConstraint(DataValidationConstraint.OperatorType.BETWEEN,
                minLocalDateTime.format(DateTimeFormatter.ofPattern(dateFormat)),
                maxLocalDateTime.format(DateTimeFormatter.ofPattern(dateFormat)),
                dateFormat);
        DataValidation validation = helper.createValidation(dataValidationConstraint, dateAddressList);
        validation.setShowErrorBox(true);
        validation.setSuppressDropDownArrow(true);
        validation.setShowErrorBox(true);
        validation.createErrorBox("标题","内容");
        sheet.addValidationData(validation);

integer 验证

bash 复制代码
// 创建数据验证助手
        DataValidationHelper helper = sheet.getDataValidationHelper();
        CellRangeAddressList intAddressList = new CellRangeAddressList(firstRow, lastRow, columnIndex, columnIndex);
        // 获取 LocalDateTime 的最大值
        LocalDateTime maxLocalDateTime = LocalDateTime.MAX;
        DataValidationConstraint dataValidationConstraint = helper.createIntegerConstraint(DataValidationConstraint.OperatorType.BETWEEN,
                String.valueOf(Integer.MIN_VALUE),
                String.valueOf(Integer.MAX_VALUE));
        DataValidation validation = helper.createValidation(dataValidationConstraint, intAddressList);
        validation.setShowErrorBox(true);
        validation.setSuppressDropDownArrow(true);
        sheet.addValidationData(validation);
相关推荐
better_liang1 天前
每日Java面试场景题知识点之-消息队列MQ核心场景与实战
java·面试·kafka·消息队列·rabbitmq·rocketmq·mq
小江的记录本1 天前
【JVM虚拟机】垃圾回收GC:四种引用类型:强引用、软引用、弱引用、虚引用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
小马爱打代码1 天前
Spring源码 第四篇:Spring 5 源码深度拆解:AOP 全流程核心原理
java·后端·spring
APIshop1 天前
Python 获取 1688 商品采集 API 接口 | 工厂货源自动化对接商品信息 | 无需选品
运维·python·自动化
deepin_sir1 天前
10 - 函数
开发语言·python
better_liang1 天前
每日Java面试场景题知识点之-SpringBoot启动流程
java·面试·springboot·源码解析·启动流程
RyFit1 天前
Java + AI 实战:Spring AI 从入门到企业级落地
java·人工智能·spring
charlee441 天前
《GIS基础原理与技术实践》配套案例(Python版)
python·conda·numpy·gis·环境配置
枫叶林FYL1 天前
项目十:事件溯源仓储管理系统(WMS)仿真实现
开发语言·python
ZhengEnCi1 天前
01-如何监听接口调用情况?
java·spring boot·后端