構文
構文は以下の通りです。
'フォームのラベルのキャプションを更新する構文
フォーム名.ラベル名.Caption = "進捗状況: " & 進捗率 & "%"
フォーム名.ラベル名.Caption = "進捗状況: " & 進捗率 & "%"
解説
フォーム名は、フォームの名前を指します。作成したフォームの名前に置き換えます。ラベル名は、フォーム内のラベルコントロールの名前です。フォーム内のラベルの名前に置き換えます。Captionは、ラベルに表示されるテキストを指定し、ラベルに表示されるテキストを動的に変更できます。
プログラミング例
具体的なプログラミング例を紹介します。
Sub 処理の進捗を表示する()
Dim 進捗率 As Integer
Dim 最大値 As Integer
Dim 回数 As Integer
' 最大値を設定
最大値 = 100
' フォームをモードレスで表示
UserForm1.Show vbModeless
UserForm1.Label1.Caption = "進捗状況: 0%"
' ループ処理を行いながら進捗を更新
For 回数 = 1 To 最大値
' 処理(ここでは1秒待機するだけ)
Application.Wait Now + TimeValue("00:00:01")
' 進捗率を計算
進捗率 = 回数 * 100 / 最大値
' ラベルのキャプションを更新
UserForm1.Label1.Caption = "進捗状況: " & 進捗率 & "%"
' 画面を更新
DoEvents
Next
' 処理完了メッセージ
UserForm1.Label1.Caption = "処理が完了しました"
End Sub
Dim 進捗率 As Integer
Dim 最大値 As Integer
Dim 回数 As Integer
' 最大値を設定
最大値 = 100
' フォームをモードレスで表示
UserForm1.Show vbModeless
UserForm1.Label1.Caption = "進捗状況: 0%"
' ループ処理を行いながら進捗を更新
For 回数 = 1 To 最大値
' 処理(ここでは1秒待機するだけ)
Application.Wait Now + TimeValue("00:00:01")
' 進捗率を計算
進捗率 = 回数 * 100 / 最大値
' ラベルのキャプションを更新
UserForm1.Label1.Caption = "進捗状況: " & 進捗率 & "%"
' 画面を更新
DoEvents
Next
' 処理完了メッセージ
UserForm1.Label1.Caption = "処理が完了しました"
End Sub
上記のプログラムは、最大値を設定して100回のループを行います。このループが処理全体を表しています。ループの中で、Application.Waitを使って1秒ごとに待機します。この部分が実際の処理に相当しますが、ここでは進捗表示の例として待機時間を使っています。ループごとに進捗率を計算し、UserForm1.Label1.Captionでラベルのテキストを更新します。DoEventsを使うことで、Excelが他のタスクを処理できるようにし、ラベルの更新が反映されるようにしています。ループが完了すると、処理完了のメッセージが表示されます。
まとめ
フォーム内のラベルを利用して進捗状況を表示するには、Label.Captionを使ってラベルに動的にテキストを表示します。進捗率を計算し、ループごとにその結果をラベルに表示することで、ユーザーに処理の進行状況を視覚的に伝えることができます。