NPOI生成下拉框

1、

HSSFSheet sheet1 = hssfworkbook.CreateSheet("Sheet1");
CellRangeAddressList regions 
= new CellRangeAddressList(06553500);
DVConstraint constraint 
= DVConstraint.CreateExplicitListConstraint(new string[] { "itemA""itemB""itemC" });
HSSFDataValidation dataValidate 
= new HSSFDataValidation(regions, constraint);
sheet1.AddValidationData(dataValidate);

 

2、

先创建一个Sheet专门用于存储下拉项的值,并将各下拉项的值写入其中:

HSSFSheet sheet2  =  hssfworkbook.CreateSheet( " ShtDictionary " );
sheet2.CreateRow(
0 ).CreateCell( 0 ).SetCellValue( " itemA " );
sheet2.CreateRow(
1 ).CreateCell( 0 ).SetCellValue( " itemB " );
sheet2.CreateRow(
2 ).CreateCell( 0 ).SetCellValue( " itemC " );

然后定义一个名称,指向刚才创建的下拉项的区域:

HSSFName range  =  hssfworkbook.CreateName();
range.Reference 
=   " ShtDictionary!$A1:$A3 " ;
range.NameName 
=   " dicRange " ;

最后,设置数据约束时指向这个名称而不是字符数组:

HSSFSheet sheet1  =  hssfworkbook.CreateSheet( " Sheet1 " );
CellRangeAddressList regions 
=   new  CellRangeAddressList( 0 65535 0 0 );

DVConstraint constraint 
=  DVConstraint.CreateFormulaListConstraint( " dicRange " );
HSSFDataValidation dataValidate 
=   new  HSSFDataValidation(regions, constraint);
sheet1.AddValidationData(dataValidate);

 

3、

         HSSFDataValidation   dataValidation = this.GetDataListValidation(result, colIndex);
         sht.AddValidationData(dataValidation);

 

         /**
         * 设置某区域的有效性规则(列表)
         * @return 生成的有效性规则
         */
        private HSSFDataValidation GetDataListValidation(string[] list, int colIndex)
        {
            //设置数据有效性作用域
            CellRangeAddressList regions = GetRegionByColIndex(colIndex);

            //生成下拉框内容
            DVConstraint constraint = DVConstraint.CreateExplicitListConstraint(list);

            //绑定下拉框和作用区域
            HSSFDataValidation data_validation = new HSSFDataValidation(regions, constraint);
            //data_validation.CreateErrorBox("输入不合法", "请输入下拉列表中的值。");
            return data_validation;
        }

 

        //根据列序号获取整列区域
        private CellRangeAddressList GetRegionByColIndex(int colIndex)
        {
            return new CellRangeAddressList(1, 65535, colIndex, colIndex);
        }

 

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值