はじめに
シートの保護をするには、最もよく使う方法がセルをロックするものでしょう。セルをロックすることで、「シートを勝手に編集してはいけないよ」というニュアンスになるので、シートのデータを不正編集したりすることを防ぐことができます。さあ、今日はSpire.XLS for .NETというライブラリを利用してエクセルでセルのロックとロック解除について紹介していきましょう。
Spire.XLS for .NETとは?
Spire.XLS for .NETは、開発者がC#やVB.NETプラットホームでExcelの文書ファイルを迅速かつ高品質で作成・編集・変換・印刷するために設計された専門的な Excelライブラリです。
中には、商用版と無料版のFree Spire.XLS for .NETがあります。Spire.XLS for .NETは商用版ではありますが、基本的な機能を搭載しているので、無料試用で日常の仕事にはもう結構だと思います。
下準備
1.E-iceblueの公式サイトからSpire.XLSをダウンロードしてください。
2.Visual Studioを起動して新規プロジェクトを作成してから、インストールされたファイルで相応しいSpire.XLS.dllを参照に追加してください。
メソッド説明
下記の表には、この機能を実行するには必要なメソッドやプロパティが含まれています。
アイテム |
説明 |
Workbook.LoadFromFile |
Loads the file. |
Workbook.SaveToFile |
Saves the file. |
XlsWorksheetBase.Protect Method |
Protects worksheet with password.protect the sheet except select lock/unlock cells. |
XlsWorksheetBase.Unprotect Method |
Unprotects this wokrsheet. |
セルロック
下記はセルをロックするステップとコードになります。
- Workbookオブジェクトを作成します。
- Workbook.LoadFromFileメソッドでファイルをロードします。
- Worksheet.Workbook プロパティでシートを取得します。
- CellStyleObject.Locked プロパティでセルをロックします。
- XlsWorksheetBase.Protectメソッドでシートを保護します。
- Workbook.SaveToFileでファイルを保存します。
```C# using Spire.Xls; namespace ConsoleApp13 { class Program { static void Main(string[] args) { //Excelロードします。 Workbook workbook = new Workbook(); workbook.LoadFromFile("Input.xlsx");
//シートをゲットします。
Worksheet sheet = workbook.Worksheets[0];
//シートのセルをロック解除します。
sheet.Range.Style.Locked = false;
//セルをロックします。
sheet.Range["A1:B3"].Style.Locked = true;
//パスワードで保護します。
sheet.Protect("123", SheetProtectionType.All);
//保存します。
workbook.SaveToFile("LockCells.xlsx");
}
}
}
<p><img src="https://cdn-ak.f.st-hatena.com/images/fotolife/l/lendoris/20211027/20211027123654.png" alt="f:id:lendoris:20211027123654p:plain" width="554" height="418" loading="lazy" title="" class="hatena-fotolife" itemprop="image" /></p>
<h1><strong>セルのロック解除</strong></h1>
<p>下記はセルをロック解除するステップとコードになります。</p>
<ol>
<li><strong><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/T_Spire_Xls_Workbook.htm">Workbook</a></strong>オブジェクトを作成します。</li>
<li><strong><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/Overload_Spire_Xls_Workbook_LoadFromFile.htm">Workbook.LoadFromFile</a></strong>メソッドでファイルをロードします。</li>
<li><strong><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/P_Spire_Xls_Worksheet_Workbook.htm">Worksheet.Workbook </a></strong>プロパティでシートを取得します。</li>
<li><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/Overload_Spire_Xls_Core_Spreadsheet_XlsWorksheetBase_Unprotect.htm"><strong>XlsWorksheetBase.</strong><strong>Unprotect</strong></a>メソッドでシートを保護解除します。</li>
<li><strong><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/P_Spire_Xls_CellStyleObject_Locked.htm">CellStyleObject.Locked </a></strong>プロパティでセルをロックします。</li>
<li><strong><a href="https://www.e-iceblue.com/apireference/net/Spire.XLS/html/Overload_Spire_Xls_Workbook_SaveToFile.htm">Workbook.SaveToFile</a></strong><strong>で</strong>ファイルを保存します。</li>
</ol>
<p> </p>
```C#
using Spire.Xls;
namespace ConsoleApp13
{
class Program
{
static void Main(string[] args)
{
//Excelをロードします。
Workbook workbook = new Workbook();
workbook.LoadFromFile("LockCells.xlsx");
//シートをゲットします。
Worksheet sheet = workbook.Worksheets[0];
//ロック解除します。
sheet.Unprotect("123");
//セルロックを解除します。
sheet.Range["A1:B3"].Style.Locked = false;
//保存します。
workbook.SaveToFile("UnlockCells.xlsx");
}
}
}
最後に
ここまで読んでくださってありがとうございます!もしSpire.XLS for .NETを利用している時にご不明なところがございましたら、ぜひご連絡ください