Protéger et déprotéger des classeurs
Pour empêcher quelqu’un de modifier, déplacer ou supprimer accidentellement ou délibérément des feuilles de calcul, vous pouvez protéger les éléments du classeur avec ou sans mot de passe. Pour protéger la structure d’un classeur afin que les feuilles de calcul du classeur ne puissent pas être déplacées, supprimées, masquées, affichées ou renommées, et que de nouvelles feuilles de calcul ne puissent pas être insérées, spécifiez le ProtectionType comme Structure.
Pour protéger Windows afin qu’ils aient la même taille et la même position chaque fois que le classeur est ouvert, spécifiez le ProtectionType comme Windows. Dans cet article, nous montrons commentprotéger etdéprotéger classeurs utilisant VSTO et Aspose.Cells for .NET pour vous permettre de comparer les deux méthodes.
Aspose.Cells fonctionne indépendamment de Microsoft Office Automation et est développé pour être facile à utiliser et produire un code soigné.
La protection d’un classeur n’empêche pas les utilisateurs de modifier les cellules. Pour protéger les données, vous devez protéger les feuilles de calcul.
Protéger un classeur
Pour ouvrir un fichier Excel Microsoft existant, protégez le classeur avec la structure et les attributs Windows et enregistrez le fichier.
Vous trouverez ci-dessous des extraits de code parallèles pour VSTO (C#, VB) et Aspose.Cells for .NET (C#, VB) qui montrent comment protéger un classeur.
VSTO
C#
.......
using Microsoft.VisualStudio.Tools.Applications.Runtime;
using Excel = Microsoft.Office.Interop.Excel;
using Office = Microsoft.Office.Core;
using System.Reflection;
.......
//Instantiate the Application object.
Excel.Application excelApp = new Excel.ApplicationClass();
//Specify the template excel file path.
string myPath = @"d:\test\MyBook.xls";
//Open the excel file.
excelApp.Workbooks.Open(myPath, Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value,
Missing.Value, Missing.Value);
//Protect the workbook specifying a password with Structure and Windows attributes.
excelApp.ActiveWorkbook.Protect("007", true, true);
//Save the file.
excelApp.ActiveWorkbook.Save();
//Quit the Application.
excelApp.Quit();
Aspose.Cells for .NET
C#
.......
using Aspose.Cells;
.......
//Specify the template excel file path.
string myPath = @"d:\test\MyBook.xls";
//Instantiate a new Workbook.
//Open the excel file.
Workbook workbook = new Workbook(myPath);
//Protect the workbook specifying a password with Structure and Windows attributes.
workbook.Protect(ProtectionType.All,"007");
//Save As the excel file.
workbook.Save(@"d:\test\MyBook.xls");
Déprotéger un classeur
Pour déprotéger un classeur, utilisez les lignes de code suivantes pour VSTO (C#, VB) et Aspose.Cells for .NET (C#, VB).
VSTO
C#
//Unprotect the workbook specifying its password.
excelApp.ActiveWorkbook.Unprotect("007");
Aspose.Cells for .NET
C#
//Unprotect the workbook specifying its password.
workbook.Unprotect("007");