C# Excel数据有效性

C# Excel数据有效性

在Excel中,大家得以应用数据有效性作用来定义哪些数据能够被输入到工作表的单元格中,例如,限制输入的数额为一定限制内的数字或使用下拉列表来界定用户可选用的多寡等。那篇文章主要分享什么使用C#编制程序的格局来促成Excel的数额有效性效率。

壹 、数字有效性

范围数量输入范围为1-10以内的数字

1.创办三个新的Excel工作薄并赢得它的第一个工作表。

Workbook wb = new Workbook();
Worksheet sheet = wb.Worksheets[0];

 

2.在单元格B9中输入一些文本并设置格式。

sheet.Range["B9"].Text = "请输入数字:";
sheet.Range["B9"].Style.Font.IsBold = true;
sheet.Range["B9"].Style.KnownColor = ExcelColors.Turquoise;

 

3.施用数字有效性到单元格C9。

sheet.Range["C9"].DataValidation.AllowType = CellDataType.Decimal;
sheet.Range["C9"].DataValidation.Formula1 = "1";
sheet.Range["C9"].DataValidation.Formula2 = "10";
sheet.Range["C9"].DataValidation.CompareOperator = ValidationComparisonOperator.Between;
sheet.Range["C9"].DataValidation.InputMessage = "请在该单元格中输入1-10之间的数字.";
sheet.Range["C9"].Style.KnownColor = ExcelColors.LightGreen1;

 

效果图:

图片 1     

                 

② 、列表有效性

界定数量输入为下拉列表中的选项

在单元格B第22中学输入一些文件并设置格式。

sheet.Range["B2"].Text = "部门:";
sheet.Range["B2"].Style.Font.IsBold = true;
sheet.Range["B2"].Style.KnownColor = ExcelColors.Turquoise;

 

应用列表有效性到单元格C2:

sheet.Range["C2"].DataValidation.Values = new string[] { "销售", "人力资源", "研发", "财务" };
sheet.Range["C2"].DataValidation.IsSuppressDropDownArrow = false;
sheet.Range["C2"].Style.KnownColor = ExcelColors.LightGreen1;

 

效果图:

图片 2 

 

③ 、自定义数据有效性错误提醒音信/警告

数据有效性应用到单元格以往,不符合须求的多寡将不能够成功的在该单元格内输入,若是强行输入不符合供给的数量,Excel将会提示如下错误消息:

图片 3

 

万一不想使用Excel默许的谬误提醒音讯,能够动用如下代码来自定义错误音信的提示内容:

sheet.Range["C2"].DataValidation.AlertStyle = AlertStyleType.Warning;
sheet.Range["C2"].DataValidation.ShowError = true;
sheet.Range["C2"].DataValidation.ErrorTitle = "错误001";
sheet.Range["C2"].DataValidation.ErrorMessage = "请从下拉列表中选择一个项目";

 

效果图:

图片 4

 

一体化代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Spire.Xls;

namespace Apply_data_validation_to_excel_cells
{
    class Program
    {
        static void Main(string[] args)
        {
            Workbook wb = new Workbook();
            Worksheet sheet = wb.Worksheets[0];

            //应用数字有效性
            sheet.Range["B9"].Text = "请输入数字:";
            sheet.Range["B9"].Style.Font.IsBold = true;
            sheet.Range["B9"].Style.KnownColor = ExcelColors.Turquoise;

            sheet.Range["C9"].DataValidation.AllowType = CellDataType.Decimal;
            sheet.Range["C9"].DataValidation.Formula1 = "1";
            sheet.Range["C9"].DataValidation.Formula2 = "10";
            sheet.Range["C9"].DataValidation.CompareOperator = ValidationComparisonOperator.Between;
            sheet.Range["C9"].DataValidation.InputMessage = "请在该单元格中输入1-10之间的数字.";
            sheet.Range["C9"].Style.KnownColor = ExcelColors.LightGreen1;

            //应用列表有效性
            sheet.Range["B2"].Text = "部门:";
            sheet.Range["B2"].Style.Font.IsBold = true;
            sheet.Range["B2"].Style.KnownColor = ExcelColors.Turquoise;

            sheet.Range["C2"].DataValidation.Values = new string[] { "销售", "人力资源", "研发", "财务" };
            sheet.Range["C2"].DataValidation.IsSuppressDropDownArrow = false;
            sheet.Range["C2"].Style.KnownColor = ExcelColors.LightGreen1;

            //自定义数据有效性错误提示信息
            sheet.Range["C2"].DataValidation.AlertStyle = AlertStyleType.Warning;
            sheet.Range["C2"].DataValidation.ShowError = true;
            sheet.Range["C2"].DataValidation.ErrorTitle = "错误001";
            sheet.Range["C2"].DataValidation.ErrorMessage = "请从下拉列表中选择一个项目"; 

            //保存文档并重启
            wb.SaveToFile("输出.xlsx",FileFormat.Version2010);
            System.Diagnostics.Process.Start("输出.xlsx");
        }
    }
}

 

总结:

本文借助了多个免费的dll文件,仅介绍了丰硕数字和列表有效性的一对,假设感兴趣的话能够下载该dll文本,然后创制别的数据有效性类型如日期/时间及文件长度有效性等。

相关文章