zoukankan      html  css  js  c++  java
  • 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(06553500);

    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);
            }

     

     

     

     

     

     

  • 相关阅读:
    spring 源码解析一(bean定义)
    IOC 容器中添加组件的方式
    spring 后置处理器
    .NetCore3.1 配置Kestrel端口的几种方式及优先级
    CESIUM空间中AB两点A绕B点的地面法向量旋转任意角度后新的A点坐标(A’)
    Cesium坐标转换:根据两个坐标点(坐标点a、坐标点b)的经纬度,计算a点和b点的角度
    任意一个点A(x,y)围绕任意一个点B(a,b)旋转任意角度后的坐标值
    已知地球上的2点坐标,A和B,求A,B线上 任意点位置。
    centos6下mysql5.7.13制作rpm包
    sql 删除狐立帐户
  • 原文地址:https://www.cnblogs.com/linzheng/p/1912173.html
Copyright © 2011-2022 走看看