Validation des données avec C++
Types de validation des données et exécution
La validation des données est la capacité de définir des règles relatives aux données saisies dans une feuille de calcul. Par exemple, utilisez la validation pour vous assurer qu’une colonne étiquetée DATE ne contient que des dates, ou qu’une autre colonne ne contient que des chiffres. Vous pourriez même vous assurer qu’une colonne étiquetée DATE ne contient que des dates dans une certaine plage. Avec la validation des données, vous pouvez contrôler ce qui est saisi dans les cellules de la feuille de calcul.
Microsoft Excel prend en charge plusieurs types de validation des données. Chaque type est utilisé pour contrôler le type de données entrées dans une cellule ou une plage de cellules. Ci-dessous, des extraits de code illustrent comment valider que:
- Les chiffres sont des entiers, c’est-à-dire qu’ils n’ont pas de partie décimale.
- Les nombres décimaux suivent la structure correcte. L’exemple de code définit qu’une plage de cellules doit avoir deux décimales.
- Les valeurs sont restreintes à une liste de valeurs. La validation de liste définit une liste distincte de valeurs qui peuvent s’appliquer à une cellule ou une plage de cellules.
- Les dates se trouvent dans une plage spécifique.
- Une heure se situe dans une plage spécifique.
- Un texte a une longueur de caractères donnée.
Validation des données avec Microsoft Excel
Pour créer des validations avec Microsoft Excel:
- Dans une feuille de calcul, sélectionnez les cellules auxquelles vous voulez appliquer la validation.
- Dans le menu Données, sélectionnez Validation. La boîte de dialogue de validation s’affichera.
- Cliquez sur l’onglet Paramètres et saisissez les paramètres.
Validation des données avec Aspose.Cells
La validation des données est une fonctionnalité puissante pour valider les informations saisies dans les feuilles de calcul. Avec la validation des données, les développeurs peuvent fournir aux utilisateurs une liste de choix, restreindre les saisies de données à un type ou une taille spécifique, etc. Dans Aspose.Cells, chaque classe Worksheet possède une propriété GetValidations() qui représente une collection d’objets Validation. Pour configurer la validation, définissez certaines propriétés de la classe Validation comme suit :
- Type : représente le type de validation, qui peut être spécifié en utilisant l’une des valeurs prédéfinies dans l’énumération ValidationType.
- Opérateur - représente l’opérateur à utiliser dans la validation, qui peut être spécifié en utilisant l’une des valeurs prédéfinies dans l’énumération OperatorType.
- Formule1 : représente la valeur ou l’expression associée à la première partie de la validation des données.
- Formule2 : représente la valeur ou l’expression associée à la deuxième partie de la validation des données.
Lorsque les propriétés de l’objet Validation ont été configurées, les développeurs peuvent utiliser la structure CellArea pour stocker des informations sur la plage de cellules qui seront validées à l’aide de la validation créée.
Types de validation des données
L’énumération ValidationType a les membres suivants:
Nom du membre | Description |
---|---|
AnyValue | Désigne une valeur de n’importe quel type. |
WholeNumber | Indique le type de validation pour les nombres entiers. |
Decimal | Indique le type de validation pour les nombres décimaux. |
List | Indique le type de validation pour la liste déroulante. |
Date | Indique le type de validation pour les dates. |
Time | Indique le type de validation pour l’heure. |
TextLength | Indique le type de validation pour la longueur du texte. |
Custom | Indique le type de validation personnalisée. |
Validation de données pour les nombres entiers
Avec ce type de validation, les utilisateurs peuvent entrer uniquement des nombres entiers dans une plage spécifiée dans les cellules validées. Les exemples de code suivants montrent comment implémenter le type de validation pour les nombres entiers. L’exemple crée la même validation des données en utilisant Aspose.Cells que celle que nous avons créée à l’aide de Microsoft Excel ci-dessus.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create a workbook object
Workbook workbook;
// Create a worksheet and get the first worksheet
Worksheet ExcelWorkSheet = workbook.GetWorksheets().Get(0);
// Accessing the Validations collection of the worksheet
ValidationCollection validations = workbook.GetWorksheets().Get(0).GetValidations();
// Create Cell Area
CellArea ca;
ca.StartRow = 0;
ca.EndRow = 0;
ca.StartColumn = 0;
ca.EndColumn = 0;
// Creating a Validation object
Validation validation = validations.Get(validations.Add(ca));
// Setting the validation type to whole number
validation.SetType(ValidationType::WholeNumber);
// Setting the operator for validation to Between
validation.SetOperator(OperatorType::Between);
// Setting the minimum value for the validation
validation.SetFormula1(u"10");
// Setting the maximum value for the validation
validation.SetFormula2(u"1000");
// Applying the validation to a range of cells from A1 to B2 using the CellArea structure
CellArea area;
area.StartRow = 0;
area.EndRow = 1;
area.StartColumn = 0;
area.EndColumn = 1;
// Adding the cell area to Validation
validation.AddArea(area);
// Save the workbook
workbook.Save(outDir + u"output.out.xls");
std::cout << "Validation applied successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Validation de données par liste
Ce type de validation permet à l’utilisateur d’entrer des valeurs à partir d’une liste déroulante. Il fournit une liste: une série de lignes contenant des données. Dans l’exemple, une deuxième feuille de calcul est ajoutée pour contenir la source de la liste. Les utilisateurs ne peuvent sélectionner que des valeurs dans la liste. La zone de validation est la plage de cellules A1:A5 dans la première feuille de calcul.
Il est important ici de définir la propriété Validation.GetInCellDropDown() à true.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create a workbook object
Workbook workbook;
// Get the first worksheet
Worksheet worksheet1 = workbook.GetWorksheets().Get(0);
// Add a new worksheet and access it
int i = workbook.GetWorksheets().Add();
Worksheet worksheet2 = workbook.GetWorksheets().Get(i);
// Create a range in the second worksheet
Range range = worksheet2.GetCells().CreateRange(u"E1", u"E4");
// Name the range
range.SetName(u"MyRange");
// Fill different cells with data in the range
range.Get(0, 0).PutValue(u"Blue");
range.Get(1, 0).PutValue(u"Red");
range.Get(2, 0).PutValue(u"Green");
range.Get(3, 0).PutValue(u"Yellow");
// Get the validations collection
ValidationCollection validations = worksheet1.GetValidations();
// Create Cell Area
CellArea ca;
ca.StartRow = 0;
ca.EndRow = 0;
ca.StartColumn = 0;
ca.EndColumn = 0;
// Create a new validation to the validations list
Validation validation = validations.Get(validations.Add(ca));
// Set the validation type
validation.SetType(ValidationType::List);
// Set the operator
validation.SetOperator(OperatorType::None);
// Set the in cell drop down
validation.SetInCellDropDown(true);
// Set the formula1
validation.SetFormula1(u"=MyRange");
// Enable it to show error
validation.SetShowError(true);
// Set the alert type severity level
validation.SetAlertStyle(ValidationAlertType::Stop);
// Set the error title
validation.SetErrorTitle(u"Error");
// Set the error message
validation.SetErrorMessage(u"Please select a color from the list");
// Specify the validation area
CellArea area;
area.StartRow = 0;
area.EndRow = 4;
area.StartColumn = 0;
area.EndColumn = 0;
// Add the validation area
validation.AddArea(area);
// Save the Excel file
workbook.Save(outDir + u"output.out.xls");
std::cout << "File saved successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Validation de données pour les dates
Avec ce type de validation, les utilisateurs saisissent des valeurs de date dans une plage spécifiée, ou répondant à des critères spécifiques, dans les cellules validées. Dans l’exemple, l’utilisateur est limité à saisir des dates entre 1970 et 1999. Ici, la zone de validation est la cellule B1.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create a workbook
Workbook workbook;
// Obtain the cells of the first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
Cells cells = worksheet.GetCells();
// Put a string value into the A1 cell
cells.Get(u"A1").PutValue(u"Please enter Date b/w 1/1/1970 and 12/31/1999");
// Set row height and column width for the cells
cells.SetRowHeight(0, 31);
cells.SetColumnWidth(0, 35);
// Get the validations collection
ValidationCollection validations = worksheet.GetValidations();
// Create Cell Area
CellArea ca;
ca.StartRow = 0;
ca.EndRow = 0;
ca.StartColumn = 0;
ca.EndColumn = 0;
// Add a new validation
int32_t validationIndex = validations.Add(ca);
Validation validation = validations.Get(validationIndex);
// Set the data validation type
validation.SetType(ValidationType::Date);
// Set the operator for the data validation
validation.SetOperator(OperatorType::Between);
// Set the value or expression associated with the data validation
validation.SetFormula1(u"1/1/1970");
// The value or expression associated with the second part of the data validation
validation.SetFormula2(u"12/31/1999");
// Enable the error
validation.SetShowError(true);
// Set the validation alert style
validation.SetAlertStyle(ValidationAlertType::Stop);
// Set the title of the data-validation error dialog box
validation.SetErrorTitle(u"Date Error");
// Set the data validation error message
validation.SetErrorMessage(u"Enter a Valid Date");
// Set and enable the data validation input message
validation.SetInputMessage(u"Date Validation Type");
validation.SetIgnoreBlank(true);
validation.SetShowInput(true);
// Set a collection of CellArea which contains the data validation settings
CellArea cellArea;
cellArea.StartRow = 0;
cellArea.EndRow = 0;
cellArea.StartColumn = 1;
cellArea.EndColumn = 1;
// Add the validation area
validation.AddArea(cellArea);
// Save the Excel file
U16String outputPath = outDir + u"output.out.xls";
workbook.Save(outputPath);
std::cout << "Excel file saved successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Validation des données de temps
Avec ce type de validation, les utilisateurs peuvent saisir des heures dans une plage spécifiée, ou répondant à certains critères, dans les cellules validées. Dans l’exemple, l’utilisateur est limité à saisir des heures entre 09h00 et 11h30. Ici, la zone de validation est la cellule B1.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create a workbook
Workbook workbook;
// Obtain the cells of the first worksheet
Cells cells = workbook.GetWorksheets().Get(0).GetCells();
// Put a string value into A1 cell
cells.Get(u"A1").PutValue(u"Please enter Time b/w 09:00 and 11:30 'o Clock");
// Set the row height and column width for the cells
cells.SetRowHeight(0, 31);
cells.SetColumnWidth(0, 35);
// Get the validations collection
ValidationCollection validations = workbook.GetWorksheets().Get(0).GetValidations();
// Create Cell Area
CellArea ca;
ca.StartRow = 0;
ca.EndRow = 0;
ca.StartColumn = 0;
ca.EndColumn = 0;
// Add a new validation
Validation validation = validations.Get(validations.Add(ca));
// Set the data validation type
validation.SetType(ValidationType::Time);
// Set the operator for the data validation
validation.SetOperator(OperatorType::Between);
// Set the value or expression associated with the data validation
validation.SetFormula1(u"09:00");
// The value or expression associated with the second part of the data validation
validation.SetFormula2(u"11:30");
// Enable the error
validation.SetShowError(true);
// Set the validation alert style
validation.SetAlertStyle(ValidationAlertType::Information);
// Set the title of the data-validation error dialog box
validation.SetErrorTitle(u"Time Error");
// Set the data validation error message
validation.SetErrorMessage(u"Enter a Valid Time");
// Set and enable the data validation input message
validation.SetInputMessage(u"Time Validation Type");
validation.SetIgnoreBlank(true);
validation.SetShowInput(true);
// Set a collection of CellArea which contains the data validation settings
CellArea cellArea;
cellArea.StartRow = 0;
cellArea.EndRow = 0;
cellArea.StartColumn = 1;
cellArea.EndColumn = 1;
// Add the validation area
validation.AddArea(cellArea);
// Save the Excel file
workbook.Save(outDir + u"output.out.xls");
std::cout << "File saved successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Validation de la longueur du texte
Avec ce type de validation, les utilisateurs peuvent saisir des valeurs textuelles d’une longueur spécifiée dans les cellules validées. Dans l’exemple, l’utilisateur est limité à saisir des valeurs de chaîne ne dépassant pas 5 caractères. La zone de validation est la cellule B1.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create a new workbook
Workbook workbook;
// Obtain the cells of the first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
Cells cells = worksheet.GetCells();
// Put a string value into A1 cell
cells.Get(u"A1").PutValue(u"Please enter a string not more than 5 chars");
// Set row height and column width for the cell
cells.SetRowHeight(0, 31);
cells.SetColumnWidth(0, 35);
// Get the validations collection
ValidationCollection validations = worksheet.GetValidations();
// Create Cell Area
CellArea ca;
ca.StartRow = 0;
ca.EndRow = 0;
ca.StartColumn = 0;
ca.EndColumn = 0;
// Add a new validation
int32_t validationIndex = validations.Add(ca);
Validation validation = validations.Get(validationIndex);
// Set the data validation type
validation.SetType(ValidationType::TextLength);
// Set the operator for the data validation
validation.SetOperator(OperatorType::LessOrEqual);
// Set the value or expression associated with the data validation
validation.SetFormula1(u"5");
// Enable the error
validation.SetShowError(true);
// Set the validation alert style
validation.SetAlertStyle(ValidationAlertType::Warning);
// Set the title of the data-validation error dialog box
validation.SetErrorTitle(u"Text Length Error");
// Set the data validation error message
validation.SetErrorMessage(u" Enter a Valid String");
// Set and enable the data validation input message
validation.SetInputMessage(u"TextLength Validation Type");
validation.SetIgnoreBlank(true);
validation.SetShowInput(true);
// Set a collection of CellArea which contains the data validation settings
CellArea cellArea;
cellArea.StartRow = 0;
cellArea.EndRow = 0;
cellArea.StartColumn = 1;
cellArea.EndColumn = 1;
// Add the validation area
validation.AddArea(cellArea);
// Save the Excel file
U16String outputPath = outDir + u"output.out.xls";
workbook.Save(outputPath);
std::cout << "File saved successfully: " << outputPath.ToUtf8() << std::endl;
Aspose::Cells::Cleanup();
}
Règles de validation des données
Lorsque les validations des données sont implémentées, la validation peut être vérifiée en attribuant différentes valeurs dans les cellules. Cell.GetValidationValue peut être utilisé pour récupérer le résultat de la validation. L’exemple suivant illustre cette fonctionnalité avec différentes valeurs. Le fichier d’exemple peut être téléchargé à partir du lien suivant pour les tests:
sampleDataValidationRules.xlsx
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Path of input Excel file
U16String inputFilePath = srcDir + u"sample.xlsx";
// Create workbook
Workbook workbook(inputFilePath);
// Access the first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
// Access Cell C1
// Cell C1 has the Decimal Validation applied on it.
// It can take only the values Between 10 and 20
Cell cell = worksheet.GetCells().Get(u"C1");
// Enter 3 inside this cell
// Since it is not between 10 and 20, it should fail the validation
cell.PutValue(3);
// Check if number 3 satisfies the Data Validation rule applied on this cell
std::cout << "Is 3 a Valid Value for this Cell: " << cell.GetValidationValue() << std::endl;
// Enter 15 inside this cell
// Since it is between 10 and 20, it should succeed the validation
cell.PutValue(15);
// Check if number 15 satisfies the Data Validation rule applied on this cell
std::cout << "Is 15 a Valid Value for this Cell: " << cell.GetValidationValue() << std::endl;
// Enter 30 inside this cell
// Since it is not between 10 and 20, it should fail the validation again
cell.PutValue(30);
// Check if number 30 satisfies the Data Validation rule applied on this cell
std::cout << "Is 30 a Valid Value for this Cell: " << cell.GetValidationValue() << std::endl;
Aspose::Cells::Cleanup();
return 0;
}
Vérifier si la validation dans la cellule est une liste déroulante
Comme nous l’avons vu, il existe de nombreux types de validations qui peuvent être mises en œuvre dans une cellule. Si vous voulez vérifier si la validation est une liste déroulante ou non, la propriété Validation.GetInCellDropDown() peut être utilisée pour le tester. Le code d’exemple suivant démontre l’utilisation de cette propriété. Un fichier d’exemple pour les tests peut être téléchargé depuis le lien suivant :
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Path of input excel file
U16String inputFilePath = srcDir + u"sampleValidation.xlsx";
// Create workbook
Workbook book(inputFilePath);
// Get worksheet
Worksheet sheet = book.GetWorksheets().Get(u"Sheet1");
// Get cells collection
Cells cells = sheet.GetCells();
// Check validation for cell A2
Cell a2 = cells.Get(u"A2");
Validation va2 = a2.GetValidation();
if (va2.GetInCellDropDown())
{
std::cout << "A2 is a dropdown" << std::endl;
}
else
{
std::cout << "A2 is NOT a dropdown" << std::endl;
}
// Check validation for cell B2
Cell b2 = cells.Get(u"B2");
Validation vb2 = b2.GetValidation();
if (vb2.GetInCellDropDown())
{
std::cout << "B2 is a dropdown" << std::endl;
}
else
{
std::cout << "B2 is NOT a dropdown" << std::endl;
}
// Check validation for cell C2
Cell c2 = cells.Get(u"C2");
Validation vc2 = c2.GetValidation();
if (vc2.GetInCellDropDown())
{
std::cout << "C2 is a dropdown" << std::endl;
}
else
{
std::cout << "C2 is NOT a dropdown" << std::endl;
}
Aspose::Cells::Cleanup();
return 0;
}
Ajouter une CellArea à une validation existante
Il peut arriver que vous vouliez ajouter CellArea à une Validation existante. Lorsque vous ajoutez CellArea en utilisant Validation.AddArea(CellArea cellArea), Aspose.Cells vérifie toutes les zones existantes pour voir si la nouvelle zone existe déjà. Si le fichier contient un grand nombre de validations, cela nuit aux performances. Pour surmonter cela, l’API fournit la méthode Validation.AddAreaCellArea cellArea, bool checkIntersection, bool checkEdge). Le paramètre checkIntersection indique s’il faut vérifier l’intersection d’une zone donnée avec les zones de validation existantes. Le définir sur false désactivera la vérification des autres zones. Le paramètre checkEdge indique s’il faut vérifier les zones appliquées. Si la nouvelle zone devient la zone en haut à gauche, les paramètres internes sont reconstruits. Si vous êtes sûr que la nouvelle zone n’est pas la zone en haut à gauche, vous pouvez définir ce paramètre sur false.
Le code suivant démontre l’utilisation de la méthode Validation.AddAreaCellArea cellArea, bool checkIntersection, bool checkEdge) pour ajouter un nouvelle CellArea à une Validation existante.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source and output directory paths
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Load the workbook
Workbook workbook(srcDir + u"ValidationsSample.xlsx");
// Access first worksheet
Worksheet worksheet = workbook.GetWorksheets().Get(0);
// Accessing the Validations collection of the worksheet
Validation validation = worksheet.GetValidations().Get(0);
// Create cell area
CellArea cellArea = CellArea::CreateCellArea(u"D5", u"E7");
// Adding the cell area to Validation
validation.AddArea(cellArea, false, false);
// Save the output workbook
workbook.Save(outDir + u"ValidationsSample_out.xlsx");
std::cout << "Validation added successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Les fichiers Excel source et de sortie sont joints pour référence.