C#使用NPOI设置Excel下拉选项

本文实例为大家分享了C#使用NPOI设置Excel下拉选项的具体代码,供大家参考,具体内容如下

最近在做一个导出模板的功能,需要限制用户的某些单元格输入的内容。

期望达到的效果:单元格中出现下拉选择,或输入错误时提示。

翻阅了许多资料,终于得到了答案。

然后自己整理下边一些方法,记录下来方便以后使用。

第一种

· 直接设置下拉值,不超过255个字符(优点:逻辑简单 ;缺点:有字符限制)

· 适用于下拉值为固定值,例如:状态、性别等

方法块:

public static void SetCellDropdownList(ISheet sheet, int firstcol, int lastcol, string[] vals)
{
     //设置生成下拉框的行和列
     var cellRegions = new CellRangeAddressList(1, 65535, firstcol, lastcol);
 
     //设置 下拉框内容
     DVConstraint constraint = DVConstraint.CreateExplicitListConstraint(vals);
 
     //绑定下拉框和作用区域,并设置错误提示信息
     HSSFDataValidation dataValidate = new HSSFDataValidation(cellRegions, constraint);
     dataValidate.CreateErrorBox("输入不合法", "请输入或选择下拉列表中的值。");
     dataValidate.ShowPromptBox = true;
 
     sheet.AddValidationData(dataValidate);
}

调用:

HSSFWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("sheet1");
ExcelHelper.SetCellDropdownList(sheet, 1, 1, new List<string>() { "男", "女", "保密" }.ToArray());

第二种

· 通过绑定值到sheet中设置下拉

· 适用于数据较多,或灵活控制的值,例如:城市区域、数据表信息等。

方法块:

public static void SetCellDropdownList(HSSFWorkbook workbook, ISheet sheet, string name, int firstcol, int lastcol, string[] vals, int sheetindex = 1)
{
      //先创建一个Sheet专门用于存储下拉项的值
      ISheet sheet2 = workbook.CreateSheet(name);
      //隐藏
      workbook.SetSheetHidden(sheetindex, true);
      int index = 0;
      foreach (var item in vals)
      {
          sheet2.CreateRow(index).CreateCell(0).SetCellValue(item);
          index++;
      }
      //创建的下拉项的区域:
      var rangeName = name + "Range";
      IName range = workbook.CreateName();
      range.RefersToFormula = name + "!$A$1:$A$" + index;
      range.NameName = rangeName;
      CellRangeAddressList regions = new CellRangeAddressList(0, 65535, firstcol, lastcol);
 
      DVConstraint constraint = DVConstraint.CreateFormulaListConstraint(rangeName);
      HSSFDataValidation dataValidate = new HSSFDataValidation(regions, constraint);
      dataValidate.CreateErrorBox("输入不合法", "请输入或选择下拉列表中的值。");
      dataValidate.ShowPromptBox = true;
      sheet.AddValidationData(dataValidate);
}

调用:

HSSFWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("sheet1");
var roomTypeList = GetRoomTypeNameList();
ExcelHelper.SetCellDropdownList(workbook, sheet, "RoomTypeDictionary", 1, 1, roomTypeList.ToArray());

另外,延伸联动下拉(直接贴源码了)

方法块:

private void SetCityCellDropdownList(HSSFWorkbook workbook, ISheet sheet, string dictionaryName, int citycol, int areacol, int sheetIndex)
{
    var citylist = GetCityList();
    int citycount = citylist.Count;
    ISheet sheet2 = workbook.CreateSheet(dictionaryName);
    //隐藏
    workbook.SetSheetHidden(sheetIndex, true);
 
    #region 城市区域数据构造
    //城市
    int rowIndex = 0;
    foreach (var item in citylist)
    {
        IRow row = sheet2.CreateRow(rowIndex);
        row.CreateCell(0).SetCellValue(item.Name);
 
        rowIndex++;
    }
    //区域
    int n_rowIndex = 0;
    foreach (var item in citylist)
    {
        int areaIndex = 0;
        foreach (var area in item.AreaList)
        {
            IRow row = sheet2.GetRow(areaIndex);
            if (row == null)
            {
                row = sheet2.CreateRow(areaIndex);
            }
            row.CreateCell(n_rowIndex + 1).SetCellValue(area.Name);
            areaIndex++;
        }
        n_rowIndex++;
    }
    #endregion
 
    #region 设置数据字段范围
    //定义城市
    int columnIndex = 1;
    IName range_Country = workbook.CreateName();
    range_Country.RefersToFormula = string.Format("{0}!${1}$1:${1}${2}", dictionaryName, GetExcelColumnName(columnIndex), citycount);
    range_Country.NameName = "城市";
 
    //定义区
    foreach (var item in citylist)
    {
        int areacount = item.AreaList.Count;
        columnIndex++;
        IName range_area = workbook.CreateName();
        range_area.RefersToFormula = string.Format("{0}!${1}$1:${1}${2}", dictionaryName, GetExcelColumnName(columnIndex), areacount);
        range_area.NameName = item.Name;
    }
 
    //城市列表下拉绑定
    ExcelHelper.SetCellDropdownList(sheet, 1, 65535, citycol, citycol, "城市");
 
    //第二列,跟随第一列联动
    string colName = GetExcelColumnName(areacol);
    for (int j = 1; j < 500; j++)
    {
        ExcelHelper.SetCellDropdownList(sheet, j, j, areacol, areacol, string.Format("INDIRECT(${0}${1})", colName, j + 1));
    }
    #endregion
}
 
private string GetExcelColumnName(int columnNumber)
{
    int dividend = columnNumber;
    string columnName = String.Empty;
    int modulo;
 
    while (dividend > 0)
    {
        modulo = (dividend - 1) % 26;
        columnName = Convert.ToChar(65 + modulo).ToString() + columnName;
        dividend = (int)((dividend - modulo) / 26);
    }
 
    return columnName;
}
public static void SetCellDropdownList(ISheet sheet, int firstRow, int lastRow, int firstCol, int lastCol, string name)
{
    CellRangeAddressList regions = new CellRangeAddressList(firstRow, lastRow, firstCol, lastCol);
    DVConstraint constraint = DVConstraint.CreateFormulaListConstraint(name);
    HSSFDataValidation dataValidate = new HSSFDataValidation(regions, constraint);
    dataValidate.CreateErrorBox("输入不合法", "请输入或选择下拉列表中的值。");
    sheet.AddValidationData(dataValidate);
}

调用:

HSSFWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("sheet1");
SetCityCellDropdownList(workbook, sheet, "CityDictionary", 1, 2, 1);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#利用NPOI操作Excel(单元格设置)

    本文实例为大家分享了C#利用NPOI操作Excel的单元格设置,供大家参考,具体内容如下 一.合并单元格 NOPI支持对单元格进行合并,还有单元格格式设置! 注意: 在进行单元格合并时必须先创建单元格 1.合并单元格语句: sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 3)); //起始行,终止行,起始列,终止列 2.设置单元格格式: ICellStyle cellStyle = wk.CreateCellStyle();  //首先建单

  • C#用NPOI导出导入Excel帮助类

    本文实例为大家分享了C#用NPOI导出导入Excel帮助类的具体代码,供大家参考,具体内容如下 1.准备工作 在管理NuGet程序包中搜索 NPOI,安装 NPOI 到要项目中. 2.帮助类 /// <summary> /// DataTable写入Excel /// </summary> /// <param name="dt"></param> /// <param name="strExcelFileName&quo

  • C#使用NPOI库读写Excel文件

    本文实例为大家分享了C#使用NPOI库读写Excel文件的具体代码,供大家参考,具体内容如下 第一步添加程引用 : 右键项目工程 — 管理 NuGet程序包 — 搜索 NOPI — 安装 对文件Excel进行操作 读取excel文件 private IWorkbook wk;   private FileStream fs;  private void OpenExcel(string path)         {             StringBuilder sbr = new Str

  • C#使用NPOI将excel导入到list的方法

    本文实例为大家分享了C#使用NPOI将excel导入到list的具体代码,供大家参考,具体内容如下 这个是确定是实体类接收 /// <summary> /// 将excel导入到list /// </summary> /// <typeparam name="T"></typeparam> /// <param name="fs">Stream 文件流</param> /// <param

  • C#通过NPOI导入导出数据EXCEL

    本文实例为大家分享了C#通过NPOI导入导出数据EXCEL的具体代码,供大家参考,具体内容如下 其实从数据库到服务器导入导出有很多方法,但是比较简单的有NPOI这个方法 准备工作,先增加到相应的lib,同时引用相关的dll 第一从数据库导出数据到Excel里面 首先我设置一个win窗体 第二步写代码 private void button1_Click(object sender, EventArgs e)         {             //查询数据,显示到表格上        

  • C# 基于NPOI操作Excel

    目录 1 单元格下拉框 2 添加批注 3 读取数据 结语 常见问题解决 NPOI 导出添加批注功能 POI导出Excel时下拉列表值超过255的问题 日期格式导入混乱 注意 1 单元格下拉框 在开发中我们会遇到为单元格设置下拉框.一般可以编写如下: var cellRanges = new CellRangeAddressList(firstRow, lastRow, firstCol, latsCol); DVConstraint constraint = DVConstraint.Creat

  • C#使用Npoi导出Excel并合并行列

    在工作开发中,客户经常要求数据库中数据导出到Excel表格.以前方法是引用office相关组件,如果客户没有安装office,功能就会遇到问题. 现在用Npoi导出Excel,导出表格是合并行列,如图: 导出的要求:合计列要进行合并,序号一致的要合并.最后一行要合并列.因为相同序号数量不是固定的,要动态算合并的行数. 合并行列接口:XXX.AddMergedRegion(new CellRangeAddress(开始行, 最后一行, 开始列, 最后一列)); 隐藏指定:sheet.SetColu

  • C#使用NPOI读取excel转为DataSet

    本文实例为大家分享了C#使用NPOI读取excel转为DataSet的具体代码,供大家参考,具体内容如下 NPOI读取excel转为DataSet /// <summary> /// 读取Execl数据到DataTable(DataSet)中 /// </summary> /// <param name="filePath">指定Execl文件路径</param> /// <param name="isFirstLineC

  • C#使用NPOI实现Excel导入导出功能

    本文实例为大家分享了C#使用NPOI实现Excel导入导出的具体代码,供大家参考,具体内容如下 Excel导入 使用OpenFileDiolog控件和button结合,选择文件导入,将路径显示在文本框 设置按钮点击事件,将文件路径赋给textBox.Text private void Department_SUM_Click(object sender, EventArgs e)         {             OpenFileDialog open = new OpenFileDi

  • c# 根据NPOI 读取一个excel 文件的多个Sheet

    大家都知道NPOI组件可以在你本地没有安装office的情况下来 读取,创建excel文件.但是大家一般都是只默认读取一个excel文件的第一个sheet.那么如果要读取一个excel 的所有sheet 要怎么做呢? 下面就来告诉大家如何操作NPOI 读取excel 的所有sheet. 首先我们先讲解操作excel 单独创建的一个类,我命名为 EXECLHELP using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF

随机推荐