Bescherm specifieke cellen in werkblad met Aspose.Cells

Invoering

In deze tutorial leiden we je door het proces van het beveiligen van specifieke cellen in een Excel-werkblad. Aan het einde kun je cellen vol vertrouwen vergrendelen als een pro, waarmee je ongeautoriseerde wijzigingen voorkomt en je werkblad flexibel houdt waar nodig.

Vereisten

Voordat we in de details duiken, willen we er zeker van zijn dat je alles hebt wat je nodig hebt om deze tutorial soepel te kunnen volgen:

  1. Visual Studio – Als u dat nog niet hebt gedaan, download en installeer dan Visual Studio. Het zal de primaire omgeving zijn waarin u uw .NET-applicaties uitvoert.
  2. Aspose.Cells voor .NET – U hebt de Aspose.Cells-bibliotheek nodig om met Excel-bestanden in uw .NET-toepassingen te werken. Als u deze nog niet hebt geïnstalleerd, kunt u de nieuwste versie downloaden van deAspose-website.
  3. .NET Framework of .NET Core – Deze tutorial werkt met zowel .NET Framework als .NET Core. Zorg er alleen voor dat uw project compatibel is met Aspose.Cells. Zodra u dit allemaal geregeld hebt, kunt u aan de slag.

Pakketten importeren

Voordat u in de stapsgewijze handleiding duikt, moet u ervoor zorgen dat u de benodigde naamruimten importeert voor het werken met Aspose.Cells. Neem de volgende import statements bovenaan uw bestand op in uw project:

using System.IO;
using Aspose.Cells;

Met deze naamruimten kunt u werken met Excel-bestanden en de klassen die nodig zijn voor de opmaak en beveiliging van de cellen in het werkblad. Laten we het nu opsplitsen in eenvoudige stappen om specifieke cellen in uw werkblad te beschermen met Aspose.Cells voor .NET. We beschermen de cellen A1, B1 en C1, terwijl we de rest van het werkblad open laten voor bewerkingen.

Stap 1: Maak een nieuwe werkmap en werkblad

Allereerst moet u een nieuwe werkmap (Excel-bestand) en een werkblad erin maken. Hier past u uw celbeveiliging toe.

// Het pad naar de documentenmap.
string dataDir = "Your Document Directory";
// Maak een map aan als deze nog niet bestaat.
bool IsExists = System.IO.Directory.Exists(dataDir);
if (!IsExists)
    System.IO.Directory.CreateDirectory(dataDir);
// Maak een nieuwe werkmap.
Workbook wb = new Workbook();
// Maak een werkbladobject en verkrijg het eerste werkblad.
Worksheet sheet = wb.Worksheets[0];

In deze stap maakt u ook een map om het resulterende Excel-bestand op te slaan als dit nog niet bestaat.Workbook klasse initialiseert een nieuw Excel-bestand enWorksheets[0] Hiermee kunnen we met het eerste blad van de werkmap werken.

Stap 2: Alle kolommen ontgrendelen

Vervolgens ontgrendelt u alle kolommen in het werkblad. Dit zorgt ervoor dat standaard alle cellen in het werkblad bewerkbaar zijn. Later vergrendelen we alleen de cellen die we willen beveiligen.

// Definieer het stijlobject.
Style style;
// Definieer het styleflag-object
StyleFlag styleflag;
// Doorloop alle kolommen in het werkblad en ontgrendel ze.
for (int i = 0; i <= 255; i++)
{
    style = sheet.Cells.Columns[(byte)i].Style;
    style.IsLocked = false;
    styleflag = new StyleFlag();
    styleflag.Locked = true;
    sheet.Cells.Columns[(byte)i].ApplyStyle(style, styleflag);
}

In dit codeblok itereren we door alle kolommen (tot 255) en stellen we deIsLocked eigendom vanfalse Dit ontgrendelt in feite alle cellen in die kolommen, waardoor ze standaard bewerkbaar zijn. Vervolgens passen we de stijl toe op de kolom met deApplyStyle() methode.

Stap 3: Vergrendel specifieke cellen (A1, B1, C1)

Nu alle kolommen ontgrendeld zijn, richten we ons op het vergrendelen van specifieke cellen, namelijk A1, B1 en C1. We passen de celstijlen aan en stellen hunIsLocked eigendom vantrue.

// Vergrendel de drie cellen...d.w.z. A1, B1, C1.
style = sheet.Cells["A1"].GetStyle();
style.IsLocked = true;
sheet.Cells["A1"].SetStyle(style);
style = sheet.Cells["B1"].GetStyle();
style.IsLocked = true;
sheet.Cells["B1"].SetStyle(style);
style = sheet.Cells["C1"].GetStyle();
style.IsLocked = true;
sheet.Cells["C1"].SetStyle(style);

Deze stap zorgt ervoor dat cellen A1, B1 en C1 vergrendeld zijn. Dit zijn de cellen die beschermd worden en niet meer bewerkt kunnen worden zodra de werkbladbeveiliging is toegepast.

Stap 4: Bescherm het werkblad

Nadat de benodigde cellen zijn vergrendeld, is de volgende stap het beschermen van het hele werkblad. Deze stap zorgt ervoor dat de vergrendelde cellen (A1, B1, C1) niet meer te bewerken zijn, terwijl andere cellen open blijven voor bewerkingen.

// Bescherm ten slotte het blad nu.
sheet.Protect(ProtectionType.All);

DeProtect methode wordt aangeroepen op het werkblad, waarbij wordt aangegeven dat alle aspecten van het werkblad moeten worden beschermd. Dit vergrendelt de specifieke cellen die zijn gemarkeerd metIsLocked = true en zorgt ervoor dat deze niet door gebruikers gewijzigd kunnen worden.

Stap 5: Sla de werkmap op

Zodra de cellen zijn vergrendeld en het werkblad is beveiligd, kunt u de werkmap op de gewenste locatie opslaan.

// Sla het Excel-bestand op.
wb.Save(dataDir + "output.out.xls", SaveFormat.Excel97To2003);

Met deze stap wordt de werkmap opgeslagen in dedataDir map met de bestandsnaamoutput.out.xls. U kunt de bestandsnaam en directory aanpassen aan uw behoeften. Het bestand is opgeslagen in Excel 97-2003-formaat, maar u kunt dit aanpassen afhankelijk van uw vereisten.

Conclusie

Het beveiligen van specifieke cellen in uw Excel-werkblad met Aspose.Cells voor .NET is een eenvoudig proces. Door de bovenstaande stappen te volgen, kunt u bepaalde cellen vergrendelen terwijl andere bewerkbaar blijven. Deze functie is uiterst nuttig bij het delen van werkmappen met anderen, omdat het u helpt bepalen welke gegevens kunnen worden gewijzigd en welke gegevens beschermd moeten blijven. Of u nu werkt met gevoelige gegevens of gewoon onbedoelde wijzigingen voorkomt, Aspose.Cells biedt een flexibele en krachtige oplossing.

Veelgestelde vragen

Hoe kan ik een specifiek cellenbereik beschermen in plaats van slechts een paar?

U kunt de code aanpassen, zodat deze door een specifiek bereik van cellen of kolommen loopt en deze vergrendelt, in plaats van dat u handmatig afzonderlijke cellen vergrendelt.

Kan ik wachtwoorden toevoegen om het werkblad te beveiligen?

Ja, u kunt een wachtwoord opgeven wanneer u deProtect() methode om te voorkomen dat gebruikers de beveiliging van het werkblad opheffen zonder het juiste wachtwoord.

Kan ik specifieke rijen of kolommen beschermen in plaats van cellen?

Ja, met Aspose.Cells kunt u hele rijen of kolommen vergrendelen door deIsLocked eigenschap voor de rijen of kolommen, vergelijkbaar met de manier waarop we cellen vergrendelden.

Hoe kan ik de beveiliging van een werkblad opheffen?

Om de beveiliging van een werkblad op te heffen, gebruikt u deUnprotect() methode, waarbij optioneel het wachtwoord wordt verstrekt als er een wachtwoord is ingesteld tijdens de bescherming.

Kan ik Aspose.Cells gebruiken voor andere Excel-bewerkingen, zoals het toevoegen van formules of grafieken?

Absoluut! Aspose.Cells is een robuuste bibliotheek waarmee u een breed scala aan Excel-bewerkingen kunt uitvoeren, waaronder het toevoegen van formules, het maken van grafieken en nog veel meer.