当前位置: 首页 > news >正文

使用 C# 设置 Excel 单元格数据验证

在日常报表开发中,Excel 的数据准确性和可控性与格式美观同样重要。通过合理设置数据验证,可以防止输入错误、约束填报规则,从而提升数据的可靠性和规范性。

相比手动设置验证规则,使用 C# 程序自动化生成 Excel 数据验证 不仅能提高效率,还能保证规则统一。本文演示如何在 同一个工作表中 设置 下拉列表、数值范围、日期区间、文本长度、自定义公式和输入提示,并结合实际业务场景帮助你理解数据验证的作用。

本文使用的方法基于 Free Spire.XLS for .NET。安装方式(NuGet)如下:

Install-Package FreeSpire.XLS

1. 初始化工作簿和工作表

using Spire.Xls;Workbook workbook = new Workbook();
Worksheet sheet = workbook.Worksheets[0];
sheet.Name = "员工信息录入";

操作说明
这里新建了一个 Excel 文件并获取第一个工作表,命名为“员工信息录入”。所有验证规则都会集中展示在这个表中,保证操作有条理。


2. 下拉列表验证(部门选择)

在实际业务中,员工部门字段通常是固定的几个选项,例如“人事部”“财务部”“技术部”“市场部”。通过下拉列表验证,可以避免用户随意输入错误部门名称。

// 部门列表
sheet.Range["A1"].Text = "可选部门:";
sheet.Range["A2"].Text = "人事部";
sheet.Range["A3"].Text = "财务部";
sheet.Range["A4"].Text = "技术部";
sheet.Range["A5"].Text = "市场部";// 员工录入区
sheet.Range["C1"].Text = "所属部门:";
CellRange deptCell = sheet.Range["C2"];deptCell.DataValidation.AllowType = CellDataType.Formula;
// 设置下拉列表数据源
deptCell.DataValidation.DataRange = sheet.Range["A2:A5"];
// 也可直接设置列表内容
//deptCell.DataValidation.Values = ["人事部", "财务部", "技术部", "市场部"];
deptCell.DataValidation.ShowError = true;
deptCell.DataValidation.AlertStyle = AlertStyleType.Stop;
deptCell.DataValidation.ErrorTitle = "输入错误";
deptCell.DataValidation.ErrorMessage = "请从下拉列表中选择部门!";// 输入提示
deptCell.DataValidation.ShowInput = true;
deptCell.DataValidation.InputTitle = "选择部门";
deptCell.DataValidation.InputMessage = "请从固定部门列表中选择。";

使用场景:避免部门名称不统一(如“技术”“技术部”混用)。

保存文件后效果:

C#设置Excel下拉列表数据验证


3. 数值验证(员工年龄)

员工年龄一般处于一定范围内,比如 18 到 60 岁。我们可以通过数值验证来限制输入。

sheet.Range["D1"].Text = "员工年龄 (18-60):";
CellRange ageCell = sheet.Range["D2"];ageCell.DataValidation.AllowType = CellDataType.Integer;
ageCell.DataValidation.CompareOperator = ValidationComparisonOperator.Between;
ageCell.DataValidation.Formula1 = "18";
ageCell.DataValidation.Formula2 = "60";
ageCell.DataValidation.ShowError = true;
ageCell.DataValidation.ErrorMessage = "请输入 18 到 60 之间的整数!";

使用场景:保证录入的年龄数据合理,不会出现“5 岁员工”或“100 岁员工”的异常数据。

保存文件后效果:

C#设置Excel数字数据验证


4. 日期验证(入职日期)

企业通常要求员工入职日期在某一合理区间内。例如,录入表只允许选择 2023 年内的入职日期。

sheet.Range["E1"].Text = "入职日期 (2023年):";
CellRange hireDateCell = sheet.Range["E2"];hireDateCell.DataValidation.AllowType = CellDataType.Date;
hireDateCell.DataValidation.CompareOperator = ValidationComparisonOperator.Between;
hireDateCell.DataValidation.Formula1 = "2023-01-01";
hireDateCell.DataValidation.Formula2 = "2023-12-31";
hireDateCell.DataValidation.ShowError = true;
hireDateCell.DataValidation.ErrorMessage = "请输入 2023 年的有效日期!";

使用场景:确保录入的入职时间不会超出考勤和人事系统设定范围。

保存文件后效果:

C#设置日期验证


5. 文本长度验证(工号)

工号通常有固定的位数,例如必须是 6 位字符。通过文本长度验证可以保证工号录入规范。

sheet.Range["F1"].Text = "工号 (6位):";
CellRange idCell = sheet.Range["F2"];idCell.DataValidation.AllowType = CellDataType.TextLength;
idCell.DataValidation.CompareOperator = ValidationComparisonOperator.Equal;
idCell.DataValidation.Formula1 = "6";
idCell.DataValidation.ShowError = true;
idCell.DataValidation.ErrorMessage = "工号必须为 6 位字符!";

使用场景:避免工号录入长度不一导致系统识别异常。

保存文件后效果:

C#设置Excel文本长度数据验证


6. 自定义公式验证(工资 > 基本工资)

在工资表中,往往需要确保“实发工资”大于“基本工资”。我们可以使用自定义公式来实现这种逻辑。

sheet.Range["G1"].Text = "基本工资:";
sheet.Range["G2"].NumberValue = 4000;
sheet.Range["H1"].Text = "实发工资:";
CellRange salaryCell = sheet.Range["H2"];salaryCell.DataValidation.AllowType = CellDataType.Formula;
salaryCell.DataValidation.Formula1 = "=H2>G2";
salaryCell.DataValidation.ShowError = true;
salaryCell.DataValidation.ErrorMessage = "实发工资必须大于基本工资!";

使用场景:避免出现“实发工资比基本工资还低”的错误数据。

保存文件后效果:

C#设置Excel公式数据验证


7. 保存文件

完成所有验证规则设置后,将结果保存为 Excel 文件:

// 自动对齐并保存
sheet.Range.Style.Font.FontName = "微软雅黑";
sheet.Range.Style.Font.Size = 12f;
sheet.Range.AutoFitColumns();
workbook.SaveToFile("DataValidation.xlsx", ExcelVersion.Version2016);

关键类与属性总结

类 / 属性说明
Workbook表示 Excel 工作簿,用于创建和保存文件
Worksheet表示 Excel 工作表,所有操作都基于该对象
CellRange表示单元格或单元格区域
DataValidation用于设置单元格数据验证规则
AllowType指定验证类型(整数、日期、文本长度、自定义公式等)
CompareOperator指定比较运算符(Between、Equal 等)
Formula1 / Formula2用于设置验证条件的参数值
ShowError是否显示错误提示
ErrorMessage错误提示信息
ShowInput是否显示输入提示
InputMessage输入提示信息

总结

本文通过 Spire.XLS for .NET 演示了如何在一张 Excel 工作表中设置多种类型的数据验证,包括下拉列表、数值范围、日期区间、文本长度、自定义公式以及输入提示。通过这些验证规则,可以有效减少错误输入,统一数据标准,提升报表质量。如果你正在开发人事、财务或其他需要批量数据录入的系统,使用 C# 自动化设置 Excel 数据验证会大大提高效率和准确性。

http://www.dtcms.com/a/409846.html

相关文章:

  • python 做 网站移动互联网终端设备的主要技术指标是什么
  • Claude Code 的“AI优先”
  • 海外网站推广的公司app开发者需要更新
  • Unity-状态机复用
  • 沈阳铁西做网站公司成都移动网站建设
  • AI提示词应用
  • 【汽车篇】AI深度学习在汽车零部件外观检测——机电轴承的应用
  • 智能网联汽车技术仿真教学软件-沉浸式学习,实战化训练
  • 深圳市网站备案百度seo哪家公司好
  • 商城网站主机在线制作论坛网站
  • 网站建设扌金手指六六wordpress开源可视化编辑
  • SpringData
  • linux docker 离线 安装
  • MyBatis常见面试题
  • Docker(一)—— Docker入门到精通:从基础概念到容器管理
  • python(44) : docker compose基于基础镜像部署python服务
  • VMware+RockyLinux+ikuai+docker+cri-docker+k8s+calico BGP网络 自用 实践笔记(四)
  • 深入理解 Docker:从入门到实践
  • 实战排查:Java 解析 Excel 大型 导致内存溢出问题的完整解决过程
  • 【实录】使用 Verdaccio 从零搭建私有 npm 仓库(含完整步骤及避坑指南)
  • 物联网人体红外检测系统详解
  • 关于Unix Domain Socket的使用入门
  • 机器视觉系统中工业相机的常见类型及其特点、应用
  • RTT操作系统(4)
  • 基于卷积神经网络的 CIFAR-10 图像分类实验报告
  • 微服务项目->在线oj系统(Java-Spring)----[前端]
  • 做网站撘框架小米手机如何做游戏视频网站
  • 如何建自己网站做淘宝客黄骅港吧
  • 交叉口内CAV调度:轨迹优化与目标速度规划,助力智能交通无缝运行!
  • Navicat 技术指引 | KingbaseES 专用 AI 助手