Skip to content

Commit 7ff4643

Browse files
264700-LockOrProtectCells
1 parent fbb2cb0 commit 7ff4643

File tree

5 files changed

+86
-0
lines changed

5 files changed

+86
-0
lines changed
Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 17
4+
VisualStudioVersion = 17.14.36127.28 d17.14
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Lock cells in worksheet", "Lock cells in worksheet\Lock cells in worksheet.csproj", "{3EBFBBB9-0A14-4886-929C-4FB78EB16777}"
7+
EndProject
8+
Global
9+
GlobalSection(SolutionConfigurationPlatforms) = preSolution
10+
Debug|Any CPU = Debug|Any CPU
11+
Release|Any CPU = Release|Any CPU
12+
EndGlobalSection
13+
GlobalSection(ProjectConfigurationPlatforms) = postSolution
14+
{3EBFBBB9-0A14-4886-929C-4FB78EB16777}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{3EBFBBB9-0A14-4886-929C-4FB78EB16777}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{3EBFBBB9-0A14-4886-929C-4FB78EB16777}.Release|Any CPU.ActiveCfg = Release|Any CPU
17+
{3EBFBBB9-0A14-4886-929C-4FB78EB16777}.Release|Any CPU.Build.0 = Release|Any CPU
18+
EndGlobalSection
19+
GlobalSection(SolutionProperties) = preSolution
20+
HideSolutionNode = FALSE
21+
EndGlobalSection
22+
GlobalSection(ExtensibilityGlobals) = postSolution
23+
SolutionGuid = {30267131-B722-4B00-8233-EC03587B9AB8}
24+
EndGlobalSection
25+
EndGlobal
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
<Project Sdk="Microsoft.NET.Sdk">
2+
3+
<PropertyGroup>
4+
<OutputType>Exe</OutputType>
5+
<TargetFramework>net8.0</TargetFramework>
6+
<RootNamespace>Lock_cells_in_worksheet</RootNamespace>
7+
<ImplicitUsings>enable</ImplicitUsings>
8+
<Nullable>enable</Nullable>
9+
</PropertyGroup>
10+
11+
<ItemGroup>
12+
<PackageReference Include="Syncfusion.XlsIO.Net.Core" Version="*" />
13+
</ItemGroup>
14+
15+
<ItemGroup>
16+
<None Update="Data\*">
17+
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
18+
</None>
19+
<None Update="Output\*">
20+
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
21+
</None>
22+
</ItemGroup>
23+
</Project>

Use Cases/Lock cells in worksheet/.NET/Lock cells in worksheet/Lock cells in worksheet/Output/.gitkeep

Whitespace-only changes.
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
using Syncfusion.XlsIO;
2+
3+
namespace Lock_Cells_In_Worksheet
4+
{
5+
class Program
6+
{
7+
public static void Main(string[] args)
8+
{
9+
using (ExcelEngine excelEngine = new ExcelEngine())
10+
{
11+
IApplication application = excelEngine.Excel;
12+
application.DefaultVersion = ExcelVersion.Xlsx;
13+
FileStream inputStream = new FileStream(Path.GetFullPath(@"Data/InputData.xlsx"), FileMode.Open, FileAccess.ReadWrite);
14+
IWorkbook workbook = application.Workbooks.Open(inputStream);
15+
IWorksheet worksheet = workbook.Worksheets[0];
16+
17+
//Unlock cells in the worksheet
18+
worksheet.UsedRange.CellStyle.Locked = false;
19+
20+
//Lock specific cells (A1:A5)
21+
worksheet.Range["A1:A5"].CellStyle.Locked = true;
22+
23+
//Protect worksheet to apply lock
24+
worksheet.Protect("password", ExcelSheetProtection.All);
25+
26+
#region Save
27+
//Saving the workbook
28+
FileStream outputStream = new FileStream(Path.GetFullPath("LockedCells.xlsx"), FileMode.Create, FileAccess.Write);
29+
workbook.SaveAs(outputStream);
30+
#endregion
31+
32+
//Dispose streams
33+
outputStream.Dispose();
34+
inputStream.Dispose();
35+
}
36+
}
37+
}
38+
}

0 commit comments

Comments
 (0)