天天看點

NPOI生成下拉框

1、

HSSFSheet sheet1 = hssfworkbook.CreateSheet("Sheet1");

CellRangeAddressList regions = new CellRangeAddressList(0, 65535, 0, 0);

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";

最後,設定資料限制時指向這個名稱而不是字元數組:

DVConstraint constraint = DVConstraint.CreateFormulaListConstraint("dicRange");

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

本文轉自linzheng 51CTO部落格,原文連結:http://blog.51cto.com/linzheng/1080852