java poi实现excle下拉框的级联

//在名称管理器中创建名称
    public HSSFName createName(HSSFWorkbook wb, String name, String expression){  

           HSSFName refer = wb.createName();  
           refer.setRefersToFormula(expression);  
           refer.setNameName(name);  
           return refer;  
        }
  
    // 使用已定义的数据源方式设置一个数据验证(选项较多的情况)  
    public DataValidation getDataValidation(String name, int firstRow, int endRow, int firstCol, int endCol){
        //加载下拉列表内容  
        DVConstraint constraint = DVConstraint.createFormulaListConstraint(name);
        //设置数据有效性加载在哪个单元格上。
        CellRangeAddressList regions=new CellRangeAddressList(firstRow,endRow,firstCol,endCol);  
        //数据有效性对象
        DataValidation data_validation_list = new HSSFDataValidation(regions,constraint);
        return data_validation_list;  

    }

//使用自定义数据源(下拉选项少的情况)
    public DataValidation getDataValidation( int firstRow, int endRow, int firstCol, int endCol){

        //加载下拉列表内容  
        String[] list={"合格","不合格"};
        DVConstraint constraint = DVConstraint.createExplicitListConstraint(list);
        //设置数据有效性加载在哪个单元格上。
        CellRangeAddressList regions=new CellRangeAddressList(firstRow,endRow,firstCol,endCol);  
        //数据有效性对象
        DataValidation data_validation_list = new HSSFDataValidation(regions,constraint);
        return data_validation_list;  

    }

    //调用以上方法
    //为地市下拉框创建名称
    POIExcelUtil.createName(wb, "city", "数据字典!$B$2:$B$"+rowcity);
    //为地市下拉框设置数据有效性
    DataValidation dataValidation = POIExcelUtil.setDataValidation("city", 2, row-1, 6, 6);
     sheet.addValidationData(dataValidation);
----------------------------------------------------------------------------------------------------------------------------------------

     //设置隐藏页标志
        workbook.setSheetHidden(workbook.getSheetIndex(hideSheetName), true);

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值