C# Excel数据有效性
2016-08-10 16:13
453 查看
在Excel中,我们可以使用数据有效性功能来定义哪些数据可以被输入到工作表的单元格中,例如,限制输入的数据为一定范围内的数字或使用下拉列表来限制用户可选择的数据等。这篇文章主要分享如何使用C#编程的方式来实现Excel的数据有效性功能。
一、数字有效性
限制数据输入范围为1-10之间的数字
1.创建一个新的Excel工作薄并获取它的第一个工作表。
2.在单元格B9中输入一些文本并设置格式。
3.应用数字有效性到单元格C9。
效果图:
二、列表有效性
限制输入数据为下拉列表中的选项
在单元格B2中输入一些文本并设置格式。
应用列表有效性到单元格C2:
效果图:
三、自定义数据有效性错误提示信息/警告
数据有效性应用到单元格以后,不符合要求的数据将不能成功的在该单元格内输入,如果强行输入不符合要求的数据,Excel将会提示如下错误信息:
如果不想使用Excel默认的错误提示信息,可以使用如下代码来自定义错误信息的提示内容:
效果图:
完整代码:
总结:
本文借助了一个免费的dll文件,仅介绍了添加数字和列表有效性的部分,如果感兴趣的话可以下载该dll文件,然后创建其他数据有效性类型如日期/时间及文本长度有效性等。
一、数字有效性
限制数据输入范围为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;
效果图:
二、列表有效性
限制输入数据为下拉列表中的选项
在单元格B2中输入一些文本并设置格式。
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;
效果图:
三、自定义数据有效性错误提示信息/警告
数据有效性应用到单元格以后,不符合要求的数据将不能成功的在该单元格内输入,如果强行输入不符合要求的数据,Excel将会提示如下错误信息:
如果不想使用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= "请从下拉列表中选择一个项目";
效果图:
完整代码:
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文件,然后创建其他数据有效性类型如日期/时间及文本长度有效性等。
相关文章推荐
- C# Excel数据有效性
- 如何通过C#保存一篇Excel文件?
- 将sql server中的数据倒入Excel(c#)
- 用C#快速往Excel写数据
- 如何使用 ASP.NET、ADO.NET 和 Visual C# .NET 查询和显示 Excel 数据
- How To Transfer XML Data to Microsoft Excel 2002 by Using Visual C# .NET
- C#中如何插入照片到Excel
- 如何使用 ASP.NET、ADO.NET 和 Visual C# .NET 查询和显示 Excel 数据
- 操作Excel(C#)
- [ASP.NET-C#]将DataSet、DataTable中的数据导出为Excel的解决方法
- C#调用操作Excel的一个类
- 使用C#进行Word 2002和Excel 2002编程
- C#与Excel的交互示例
- 将sql server中的数据倒入Excel(c#)
- C# 操作 Excel
- Excel Exchange and C#
- C#操作Excel常用语句
- 使用C#进行Word 2002和Excel 2002编程
- 如何使用 ASP.NET、ADO.NET 和 Visual C# .NET 查询和显示 Excel 数据
- C#中操作Excel的方法(二)之技巧篇