Excel VBA オプションボタンで一つの選択肢を選ぶコントロールの使い方

 

Excel VBA のオプションボタン(ラジオボタン)は、ユーザーに一つの選択肢を選ばせるためのコントロールです。複数のオプションボタンの中で一つだけ選択できるようになっています。具体的な使い方や、注意点やサンプルコードを紹介します。

 

📌 「これ、自動化できたらラクなのに…」と思ったこと、ありませんか?
実はその作業、Excelマクロで簡単に自動化できるかもしれません。
「でもマクロって難しそう…」という方のために、完全初心者向けの入門記事をご用意しました!

👇実務で“そのまま使える”テンプレ付きで、コピペするだけ
初心者向けエクセルマクロの作り方を解説|コピペOK実務テンプレ付き

 

Excel VBA オプションボタンの利用

以下のようなシーンで利用されます。

・フォームやユーザーフォームにおいて、複数の選択肢から一つを選ばせる

・設定やオプションの選択を必要とする

 

Excel VBA オプションボタンの使い方とポイント

使い方

オプションボタンをユーザーフォームやワークシートに配置し、VBAコードでその選択状態を取得・操作します。

 

ポイント

・同じグループ内のオプションボタンは、一つの選択肢しか選択できません。グループ化はフォームのフレームコントロールなどを使って行います。

・オプションボタンの状態を取得する場合は、その Value プロパティを確認します。

 

Excel VBA オプションボタンのサンプルコード

ユーザーフォームに配置したオプションボタンの状態を取得して選択されたオプションに応じた処理を行う例

1.ユーザーフォームの作成
① Excelの開発タブを開き、ユーザーフォームを挿入します。
② ユーザーフォームに3つのオプションボタン(OptionButton1、OptionButton2、OptionButton3)を配置します。
③コマンドボタン(CommandButton1)を配置して、クリック時に選択結果を表示します。

2.VBAコードの追加
以下のコードをユーザーフォームのコードウィンドウに追加します。

Option Explicit

Private Sub CommandButton1_Click()
    Dim selectedOption As String
    
    If OptionButton1.Value = True Then
        selectedOption = "オプション1が選択されました。"
    ElseIf OptionButton2.Value = True Then
        selectedOption = "オプション2が選択されました。"
    ElseIf OptionButton3.Value = True Then
        selectedOption = "オプション3が選択されました。"
    Else
        selectedOption = "オプションが選択されていません。"
    End If
    
    MsgBox selectedOption
End Sub

 

自分の実力を客観的にチェックしたい…。そんな方のために、自分に合ったスタート地点がわかる無料のExcelVBAベーシック選択問題集をご用意しました。

👉無料ExcelVBAベーシック選択問題138問

 

1.ユーザーフォームを表示する以下のコードを標準モジュールに追加して、ユーザーフォームを表示します。

Option Explicit

Sub ShowUserForm()
    UserForm1.Show
End Sub

2.ユーザーフォームを実行する Alt + F8 を押して「マクロ」ダイアログを開き、ShowUserForm を選択して実行します。

 

オプションボタンは、ユーザーが複数の選択肢の中から一つを選ぶ場面で役立ちます。VBAコードを使って選択状態を取得し、適切な処理を行うことができます。同じグループ内のオプションボタンを使う際は、フレームなどでグループ化することを忘れないようにしましょう。

 

Excel VBAエキスパートベーシックとスタンダード、どちらを選べばいいか判断が難しい…。そんな方のために、自分に合ったスタート地点がわかる無料のExcelVBAベーシック選択問題集を用意しました。

👉無料ExcelVBAベーシック選択問題138問