
Excel VBA Private Subは、VBAプロシージャ(サブルーチン)が他のモジュールからアクセスされないようにするために使用します。このサブルーチンを含むモジュール内でのみ実行できるようにします。具体的な使い方や、注意点やサンプルコードを紹介します。
Excel VBAの資格でキャリアアップ!
就活や転職で有利になるVBAエキスパート資格を解説!
👉 VBAエキスパート資格のメリットを詳しく知る
Excel VBA Private Subを利用
以下のようなシーンで利用されます。
・モジュール内でのみ必要なサブルーチンを作成する。
・他のモジュールからのアクセスを防ぐことで、意図しない実行を避けたい場合。
・プログラムの構造を整理し、他の部分に影響を与えないようにする。
Excel VBA Private Subの使い方とポイント
Private Sub SubName()
' サブルーチンのコード
End Sub
・Private Subは、同じモジュール内の他のプロシージャや関数からは呼び出すことができますが、他のモジュールからは呼び出せません。
・サブルーチンがプライベートであることを明確にすることで、コードの可読性と保守性が向上します。
・意図的にプライベートにしている場合、将来の変更時に他のモジュールからアクセスが必要になる場合は修正が必要です。
Excel VBA Private Subのサンプルコード
Excel VBAの資格でキャリアアップ!
就活や転職で有利になるVBAエキスパート資格を解説!
👉 VBAエキスパート資格のメリットを詳しく知る
Option Explicit
' このモジュールの他のプロシージャから呼び出せるプライベートサブルーチン
Private Sub DisplayMessage()
MsgBox "これはプライベートサブルーチンです。"
End Sub
' パブリックサブルーチンからプライベートサブルーチンを呼び出す例
Public Sub CallPrivateSub()
DisplayMessage
End Sub
1. Private Sub DisplayMessage()
このサブルーチンはプライベートであり、このモジュール内でのみ使用できます。
MsgBox関数を使用してメッセージを表示します。
2. Public Sub CallPrivateSub()
このサブルーチンはパブリックであり、他のモジュールからも呼び出すことができます。
このサブルーチン内でプライベートサブルーチンDisplayMessageを呼び出します。
DisplayMessageサブルーチンはモジュール内でのみ使用でき、他のモジュールから直接アクセスすることはできません。代わりに、CallPrivateSubを介してDisplayMessageを呼び出すことができます。これにより、DisplayMessageのコードが外部から直接アクセスされることを防ぎ、コードの安全性と整合性を保つことができます。
Excel VBAの資格でキャリアアップ!
就活や転職で有利になるVBAエキスパート資格を解説!