Validation de données
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 de données avec Aspose.Cells for Node.js via C++
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 for Node.js via C++, chaque classe Worksheet possède une méthode 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 sera validée à 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 ne peuvent entrer que des nombres entiers dans une plage spécifiée dans les cellules validées. Les exemples de code qui suivent montrent comment implémenter le type de validation NombreEntier. L’exemple crée la même validation de données en utilisant Aspose.Cells for Node.js via C++ que celle que nous avons créée avec Microsoft Excel ci-dessus.
const path = require("path"); | |
const AsposeCells = require("aspose.cells.node"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Create directory if it is not already present. | |
const fs = require("fs"); | |
if (!fs.existsSync(dataDir)) { | |
fs.mkdirSync(dataDir); | |
} | |
// Create a workbook object. | |
const workbook = new AsposeCells.Workbook(); | |
// Create a worksheet and get the first worksheet. | |
const ExcelWorkSheet = workbook.getWorksheets().get(0); | |
// Accessing the Validations collection of the worksheet | |
const validations = workbook.getWorksheets().get(0).getValidations(); | |
// Create Cell Area | |
const ca = new AsposeCells.CellArea(); | |
ca.startRow = 0; | |
ca.endRow = 0; | |
ca.startColumn = 0; | |
ca.endColumn = 0; | |
// Creating a Validation object | |
const validation = validations.get(validations.add(ca)); | |
// Setting the validation type to whole number | |
validation.setType(AsposeCells.ValidationType.WholeNumber); | |
// Setting the operator for validation to Between | |
validation.setOperator(AsposeCells.OperatorType.Between); | |
// Setting the minimum value for the validation | |
validation.setFormula1("10"); | |
// Setting the maximum value for the validation | |
validation.setFormula2("1000"); | |
// Applying the validation to a range of cells from A1 to B2 using the | |
// CellArea structure | |
const area = new AsposeCells.CellArea(); | |
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(path.join(dataDir, "output.out.xls")); |
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.setInCellDropDown(boolean) sur true.
const AsposeCells = require("aspose.cells.node"); | |
const path = require("path"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Create directory if it is not already present. | |
const fs = require("fs"); | |
if (!fs.existsSync(dataDir)) { | |
fs.mkdirSync(dataDir); | |
} | |
// Create a workbook object. | |
let workbook = new AsposeCells.Workbook(); | |
// Get the first worksheet. | |
let worksheet1 = workbook.getWorksheets().get(0); | |
// Add a new worksheet and access it. | |
let i = workbook.getWorksheets().add(); | |
let worksheet2 = workbook.getWorksheets().get(i); | |
// Create a range in the second worksheet. | |
let range = worksheet2.getCells().createRange("E1", "E4"); | |
// Name the range. | |
range.setName("MyRange"); | |
// Fill different cells with data in the range. | |
range.get(0, 0).putValue("Blue"); | |
range.get(1, 0).putValue("Red"); | |
range.get(2, 0).putValue("Green"); | |
range.get(3, 0).putValue("Yellow"); | |
// Get the validations collection. | |
let validations = worksheet1.getValidations(); | |
// Create Cell Area | |
let ca = new AsposeCells.CellArea(); | |
ca.startRow = 0; | |
ca.endRow = 0; | |
ca.startColumn = 0; | |
ca.endColumn = 0; | |
// Create a new validation to the validations list. | |
let validation = validations.get(validations.add(ca)); | |
// Set the validation type. | |
validation.setType(AsposeCells.ValidationType.List); | |
// Set the operator. | |
validation.setOperator(AsposeCells.OperatorType.None); | |
// Set the in cell drop down. | |
validation.setInCellDropDown(true); | |
// Set the formula1. | |
validation.setFormula1("=MyRange"); | |
// Enable it to show error. | |
validation.setShowError(true); | |
// Set the alert type severity level. | |
validation.setAlertStyle(AsposeCells.ValidationAlertType.Stop); | |
// Set the error title. | |
validation.setErrorTitle("Error"); | |
// Set the error message. | |
validation.setErrorMessage("Please select a color from the list"); | |
// Specify the validation area. | |
let area = new AsposeCells.CellArea(); | |
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(path.join(dataDir, "output.out.xls")); |
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.
const path = require("path"); | |
const AsposeCells = require("aspose.cells.node"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Create directory if it is not already present. | |
const fs = require("fs"); | |
if (!fs.existsSync(dataDir)) { | |
fs.mkdirSync(dataDir); | |
} | |
// Create a workbook. | |
let workbook = new AsposeCells.Workbook(); | |
// Obtain the cells of the first worksheet. | |
let cells = workbook.getWorksheets().get(0).getCells(); | |
// Put a string value into the A1 cell. | |
cells.get("A1").putValue("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. | |
let validations = workbook.getWorksheets().get(0).getValidations(); | |
// Create Cell Area | |
let ca = new AsposeCells.CellArea(); | |
ca.startRow = 0; | |
ca.endRow = 0; | |
ca.startColumn = 0; | |
ca.endColumn = 0; | |
// Add a new validation. | |
let validation = validations.get(validations.add(ca)); | |
// Set the data validation type. | |
validation.setType(AsposeCells.ValidationType.Date); | |
// Set the operator for the data validation | |
validation.setOperator(AsposeCells.OperatorType.Between); | |
// Set the value or expression associated with the data validation. | |
validation.setFormula1("1/1/1970"); | |
// The value or expression associated with the second part of the data validation. | |
validation.setFormula2("12/31/1999"); | |
// Enable the error. | |
validation.setShowError(true); | |
// Set the validation alert style. | |
validation.setAlertStyle(AsposeCells.ValidationAlertType.Stop); | |
// Set the title of the data-validation error dialog box | |
validation.setErrorTitle("Date Error"); | |
// Set the data validation error message. | |
validation.setErrorMessage("Enter a Valid Date"); | |
// Set and enable the data validation input message. | |
validation.setInputMessage("Date Validation Type"); | |
validation.setIgnoreBlank(true); | |
validation.setShowInput(true); | |
// Set a collection of CellArea which contains the data validation settings. | |
let cellArea = new AsposeCells.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(path.join(dataDir, "output.out.xls")); |
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.
const AsposeCells = require("aspose.cells.node"); | |
const path = require("path"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Create directory if it is not already present. | |
if (!require("fs").existsSync(dataDir)) { | |
require("fs").mkdirSync(dataDir); | |
} | |
// Create a workbook. | |
const workbook = new AsposeCells.Workbook(); | |
// Obtain the cells of the first worksheet. | |
const cells = workbook.getWorksheets().get(0).getCells(); | |
// Put a string value into A1 cell. | |
cells.get("A1").putValue("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. | |
const validations = workbook.getWorksheets().get(0).getValidations(); | |
// Create Cell Area | |
const ca = new AsposeCells.CellArea(); | |
ca.startRow = 0; | |
ca.endRow = 0; | |
ca.startColumn = 0; | |
ca.endColumn = 0; | |
// Add a new validation. | |
const validation = validations.get(validations.add(ca)); | |
// Set the data validation type. | |
validation.setType(AsposeCells.ValidationType.Time); | |
// Set the operator for the data validation. | |
validation.setOperator(AsposeCells.OperatorType.Between); | |
// Set the value or expression associated with the data validation. | |
validation.setFormula1("09:00"); | |
// The value or expression associated with the second part of the data validation. | |
validation.setFormula2("11:30"); | |
// Enable the error. | |
validation.setShowError(true); | |
// Set the validation alert style. | |
validation.setAlertStyle(AsposeCells.ValidationAlertType.Information); | |
// Set the title of the data-validation error dialog box. | |
validation.setErrorTitle("Time Error"); | |
// Set the data validation error message. | |
validation.setErrorMessage("Enter a Valid Time"); | |
// Set and enable the data validation input message. | |
validation.setInputMessage("Time Validation Type"); | |
validation.setIgnoreBlank(true); | |
validation.setShowInput(true); | |
// Set a collection of CellArea which contains the data validation settings. | |
const cellArea = new AsposeCells.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(path.join(dataDir, "output.out.xls")); |
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.
const path = require("path"); | |
const AsposeCells = require("aspose.cells.node"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Create directory if it is not already present. | |
if (!require("fs").existsSync(dataDir)) { | |
require("fs").mkdirSync(dataDir); | |
} | |
// Create a new workbook. | |
const workbook = new AsposeCells.Workbook(); | |
// Obtain the cells of the first worksheet. | |
const cells = workbook.getWorksheets().get(0).getCells(); | |
// Put a string value into A1 cell. | |
cells.get("A1").putValue("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. | |
const validations = workbook.getWorksheets().get(0).getValidations(); | |
// Create Cell Area | |
const ca = new AsposeCells.CellArea(); | |
ca.startRow = 0; | |
ca.endRow = 0; | |
ca.startColumn = 0; | |
ca.endColumn = 0; | |
// Add a new validation. | |
const validation = validations.get(validations.add(ca)); | |
// Set the data validation type. | |
validation.setType(AsposeCells.ValidationType.TextLength); | |
// Set the operator for the data validation. | |
validation.setOperator(AsposeCells.OperatorType.LessOrEqual); | |
// Set the value or expression associated with the data validation. | |
validation.setFormula1("5"); | |
// Enable the error. | |
validation.setShowError(true); | |
// Set the validation alert style. | |
validation.setAlertStyle(AsposeCells.ValidationAlertType.Warning); | |
// Set the title of the data-validation error dialog box. | |
validation.setErrorTitle("Text Length Error"); | |
// Set the data validation error message. | |
validation.setErrorMessage(" Enter a Valid String"); | |
// Set and enable the data validation input message. | |
validation.setInputMessage("TextLength Validation Type"); | |
validation.setIgnoreBlank(true); | |
validation.setShowInput(true); | |
// Set a collection of CellArea which contains the data validation settings. | |
const cellArea = new AsposeCells.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(path.join(dataDir, "output.out.xls")); |
Règles de validation des données
Lors de l’implémentation des validations, la validation peut être vérifiée en assignant différentes valeurs dans les cellules. Cell.getValidationValue() peut être utilisé pour récupérer le résultat de la validation. L’exemple suivant montre cette fonctionnalité avec différentes valeurs. Le fichier d’échantillon peut être téléchargé via le lien suivant pour test :
sampleDataValidationRules.xlsx
const AsposeCells = require("aspose.cells.node"); | |
const path = require("path"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
// Instantiate the workbook from sample Excel file | |
const workbook = new AsposeCells.Workbook(dataDir + "sample.xlsx"); | |
// Access the first worksheet | |
const 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 | |
const cell = worksheet.getCells().get("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 | |
console.log("Is 3 a Valid Value for this Cell: " + cell.getValidationValue()); | |
// 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 | |
console.log("Is 15 a Valid Value for this Cell: " + cell.getValidationValue()); | |
// 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 | |
console.log("Is 30 a Valid Value for this Cell: " + cell.getValidationValue()); |
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 implémentés dans une cellule. Si vous souhaitez vérifier si la validation est un menu déroulant ou non, la méthode Validation.getInCellDropDown() peut être utilisée pour tester cela. Le code d’échantillon ci-dessous montre l’utilisation de cette propriété. Un fichier d’échantillon pour tester peut être téléchargé via le lien suivant :
const AsposeCells = require("aspose.cells.node"); | |
const path = require("path"); | |
// The path to the documents directory. | |
const dataDir = path.join(__dirname, "data"); | |
const workbook = new AsposeCells.Workbook(dataDir + "sampleValidation.xlsx"); | |
const sheet = workbook.getWorksheets().get("Sheet1"); | |
const cells = sheet.getCells(); | |
const checkDropDown = (cell, cellRef) => { | |
const validation = cell.getValidation(); | |
if (validation.getInCellDropDown()) { | |
console.log(`${cellRef} is a dropdown`); | |
} else { | |
console.log(`${cellRef} is NOT a dropdown`); | |
} | |
}; | |
checkDropDown(cells.get("A2"), "A2"); | |
checkDropDown(cells.get("B2"), "B2"); | |
checkDropDown(cells.get("C2"), "C2"); |
Ajouter une CellArea à une validation existante
Il peut y avoir des cas où vous souhaitez ajouter CellArea à Validation existantes. Lorsque vous ajoutez CellArea en utilisant Validation.addArea(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 impacte la performance. Pour éviter cela, l’API fournit la méthode Validation.addArea(CellArea, boolean, boolean). Le paramètre checkIntersection indique s’il faut vérifier l’intersection d’une zone donnée avec les zones de validation existantes. La mise à 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 reconstruit. Si vous êtes certain que la nouvelle zone n’est pas en haut à gauche, vous pouvez définir ce paramètre sur false.
Le code suivant illustre l’utilisation de la méthode Validation.addArea(CellArea, boolean, boolean) pour ajouter un CellArea à Validation existants.
const path = require("path"); | |
const AsposeCells = require("aspose.cells.node"); | |
// The path to the documents directory. | |
const sourceDir = path.join(__dirname, "data"); | |
const outputDir = path.join(__dirname, "output"); | |
const workbook = new AsposeCells.Workbook(path.join(sourceDir, "ValidationsSample.xlsx")); | |
// Access first worksheet. | |
const worksheet = workbook.getWorksheets().get(0); | |
// Accessing the Validations collection of the worksheet | |
const validation = worksheet.getValidations().get(0); | |
// Create your cell area. | |
const cellArea = AsposeCells.CellArea.createCellArea("D5", "E7"); | |
// Adding the cell area to Validation | |
validation.addArea(cellArea, false, false); | |
// Save the output workbook. | |
workbook.save(path.join(outputDir, "ValidationsSample_out.xlsx")); |
Les fichiers Excel source et de sortie sont joints pour référence.