微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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["].Style.Font.IsBold = true"].Style.KNownColor = ExcelColors.Turquoise;

 

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

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

 

效果图:

     

                 

二、列表有效性

限制数据输入为下拉列表中的选项

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

sheet.Range[B2部门:"].Style.KNownColor = ExcelColors.Turquoise;

 

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

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

 

效果图:

 

 

三、自定义数据有效性错误提示信息/警告

数据有效性应用到单元格以后,不符合要求的数据将不能成功的在该单元格内输入,如果强行输入不符合要求的数据,Excel将会提示如下错误信息:

 

如果不想使用Excel认的错误提示信息,可以使用如下代码自定义错误信息的提示内容

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

 

效果图:

 

完整代码

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

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

            //应用数字有效性
            sheet.Range[;
            sheet.Range["].Style.KNownColor = ExcelColors.Turquoise;

            sheet.Range[ CellDataType.Decimal;
            sheet.Range[ ValidationComparisonoperator.Between;
            sheet.Range[ ExcelColors.LightGreen1;
 
            应用列表有效性
            sheet.Range[ };
            sheet.Range[ ExcelColors.LightGreen1;

            自定义数据有效性错误提示信息
            sheet.Range[ AlertStyleType.Warning;
            sheet.Range[; 

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

 

总结:

本文借助了一个免费的dll文件,仅介绍了添加数字和列表有效性的部分,如果感兴趣的话可以下载该dll文件,然后创建其他数据有效性类型如日期/时间及文本长度有效性等。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐