数据验证

数据验证类型和执行

Microsoft Excel 支持多种不同类型的数据验证。每种类型用于控制将什么类型的数据输入单元格或单元格范围。下面的代码片段说明了如何验证这一点:

使用 Microsoft Excel 进行数据验证

使用 Microsoft Excel 创建验证:

  1. 在工作表中,选择要应用验证的单元格。

  2. 来自数据菜单,选择验证. 显示验证对话框。

  3. 点击设置选项卡并输入设置,如下所示。

    数据验证设置

待办事项:图片_替代_文本

使用 Aspose.Cells 进行数据验证

数据验证是一项强大的功能,用于验证输入到工作表中的信息。通过数据验证,开发人员可以为用户提供选择列表,将数据条目限制为特定类型或大小等。 在 Aspose.Cells 中,每个工作表类有一个验证代表集合的对象验证对象。要设置验证,请设置一些验证类的属性:

  • 类型:表示验证类型,可以通过使用中的预定义值之一来指定验证类型枚举。
  • 操作员:表示要在验证中使用的运算符,可以通过使用中的预定义值之一来指定运算符类型枚举。
  • 公式1:表示与数据验证的第一部分关联的值或表达式。
  • 方程式2:表示与数据验证的第二部分关联的值或表达式。

当。。。的时候验证对象的属性已经配置好,开发者可以使用单元格区域结构来存储有关将使用创建的验证进行验证的单元格范围的信息。

数据验证类型

数据验证允许您将业务规则构建到每个单元格中,以便不正确的条目会导致错误消息。业务规则是管理业务运作方式的政策和程序。 Aspose.Cells 支持所有重要类型的数据验证。

验证类型枚举有以下成员:

成员名字 描述
ANY_VALUE 表示任何类型的值。
完整的号码 表示整数的验证类型。
十进制 表示十进制数的验证类型。
列表 表示下拉列表的验证类型。
日期 表示日期的验证类型。
时间 表示时间的验证类型。
TEXT_LENGTH 表示文本长度的验证类型。
风俗 表示自定义验证类型。

编程示例:整数数据验证

通过这种类型的验证,用户只能将指定范围内的整数输入到已验证的单元格中。下面的代码示例显示了如何实现完整的号码验证类型。该示例使用我们在上面使用 Microsoft Excel 创建的 Aspose.Cells 创建相同的数据验证。

编程示例:十进制数据验证

通过这种类型的验证,用户可以将十进制数字输入到已验证的单元格中。在示例中,限制用户只能输入十进制值,验证区域为 A1:A10。

编程示例:列表数据验证

这种类型的验证允许用户从下拉列表中输入值。它提供了一个列表:一系列包含数据的行。用户只能从列表中选择值。验证区域是第一个工作表中的单元格区域 A1:A5。

在这里设置是很重要的验证.setInCellDropDown财产给真的.

编程示例:日期数据验证

通过这种类型的验证,用户可以在指定范围内或满足特定条件的日期值输入到已验证的单元格中。在示例中,用户只能输入 1970 到 1999 之间的日期。这里,验证区域是 B1 单元格。

编程示例:时间数据验证

通过这种类型的验证,用户可以在指定范围内或满足某些条件的时间输入已验证的单元格。在示例中,用户只能输入 09:00 到 11:30 AM 之间的时间。这里,验证区域是 B1 单元格。

编程示例:文本长度数据验证

通过这种类型的验证,用户可以将指定长度的文本值输入到已验证的单元格中。在示例中,用户被限制输入不超过 5 个字符的字符串值。验证区域是 B1 单元格。

数据验证规则

实施数据验证后,可以通过在单元格中分配不同的值来检查验证。Cell.GetValidationValue() 可用于获取验证结果。以下示例使用不同的值演示了此功能。示例文件可以从以下链接下载进行测试:

示例数据验证规则.xlsx

示例代码

检查单元格中的验证是否下拉

正如我们所见,可以在一个单元格中实现多种类型的验证。如果你想检查验证是否下拉,验证.InCellDropDown属性可用于对此进行测试。以下示例代码演示了此属性的用法。用于测试的示例文件可以从以下链接下载:

示例数据验证规则.xlsx

将 CellArea 添加到现有验证

在某些情况下,您可能想要添加单元格区域对现有的验证.当你添加单元格区域使用Validation.AddArea(CellArea 单元格区域), Aspose.Cells 检查所有存在的区域,看新区域是否已经存在。如果文件有大量验证,这会影响性能。为了克服这个问题,API 提供了[Validation.AddAreaCellArea cellArea, bool checkIntersection, bool checkEdge)](https://reference.aspose.com/cells/java/com.aspose.cells/Validation#addArea(com.aspose.cells.CellArea,%20boolean,%20boolean)) 方法。这检查交叉路口参数指示是否检查给定区域与现有验证区域的交集。将其设置为错误的将禁用其他区域的检查。这检查边缘参数表示是否勾选应用区域。如果新区域成为左上角区域,则内部设置将被重建。如果您确定新区域不是左上角区域,您可以将此参数设置为错误的.

下面的代码片段演示了使用[Validation.AddAreaCellArea cellArea, bool checkIntersection, bool checkEdge)](https://reference.aspose.com/cells/java/com.aspose.cells/Validation#addArea(com.aspose.cells.CellArea,%20boolean,%20boolean)添加新方法单元格区域对现有的验证.

附上源文件和输出 excel 文件以供参考。

源文件

输出文件

推进主题