ExcelマクロVBA入門
第22回.条件分岐(Select Case)

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日:2019-08-25

第22回.条件分岐(Select Case)


マクロ VBA Select Case

前回のElseIf以外の、多肢条件分岐の別の書き方があります。


それがSelect Caseになります。
むしろElseIfより、このSelect Caseの方が、より多肢条件分岐に適していると言えます。
Select Caseは、多肢条件分岐に特化したステートメントになります。

Select Caseステートメントの構文

Select Case testexpression
    [Case expressionlist-n
        [statements-n]]
    ・・・
    [Case Else
        [elsestatements]]
End Select



testexpression 必ず指定します。
任意の数式または文字列式を指定します。
expressionlist-n

Case 節がある場合は、必ず指定します。次の形式で指定します。
また、複数指定するときは、カンマ (,) で区切ります。
expression
expression To expressionIs
comparisonoperator expression
引数 expression には数式または文字列を、引数 comparisonoperator には比較演算子を指定します。
キーワード To は、値の範囲を指定するキーワードです。
キーワード To を使って値の範囲を指定するときは、小さい方の値を先 (左側) に指定してください。
キーワード Is は、値の範囲を指定するキーワードで、Is 演算子と Like 演算子以外の比較演算子と共に使われます。
キーワード Is は指定しなくても自動的に設定されます。

statements-n 省略可能です。
引数 testexpression が引数 expressionlist-n のいずれかと一致するとき、一致した引数 statements-n のステートメントが実行されます。
elsestatements 省略可能です。
引数 testexpression が Case 節のいずれとも一致しないとき、引数 elsestatements のステートメントが実行されます。

※これは、ヘルプからの抜粋です。

少し解りずらいです、特にexpressionlist-nについての指定が解りずらいと思います。
以下の例文で理解を深めてください。

Select Case の例文

まずは基本形
Select Case 変数
  Case 1
    '変数=1の処理
  Case 2
    '変数=2の処理
  Case Else
    '変数が上記以外の処理
End Select

Or条件の書き方

Select Case 変数
  Case 1, 2
    '変数=1 Or 変数=2の処理
  Case 3, 4, 5
    '変数=3 Or 変数=4 Or 変数=5の処理
  Case Else
    '変数が上記以外の処理
End Select


範囲指定


Select Case 変数
  Case 1 To 2
    '変数=1 ~ 2の処理
  Case 3 To 5
    '変数=3 ~ 5の処理
  Case Else
    '変数が上記以外の処理
End Select


不等号の使い方

Select Case 変数
  Case Is <= 2 'Is は書かなければ自動挿入されます。
    '変数<=2の処理
  Case Is <= 5
    '変数<= 5の処理
  Case Else
    '変数が上記以外の処理
End Select


Select Caseは、とても使い道が広い汎用的なステートメントです。
If~ElseIf~End Ifは、Select Caseで書き直すことが出来ます。

ElseIfを使ってVBAを書いた場合

If 条件式1 Then
  '条件式1が真の処理
ElseIf 条件式2 Then
  '条件式2が真の処理
ElseIf 条件式3 Then
  '条件式3が真の処理
Else
  '全ての条件式が偽の処理
End If


Select CaseでVBAを書いた場合
Select Case True
  Case 条件式1
    '条件式1が真の処理
  Case 条件式2
    '条件式2が真の処理
  Case 条件式3
    '条件式3が真の処理
  Case Else
    '全ての条件式が偽の処理
End Select

上記2つ(ElseIfとSelect Case)は、同一となります。
私は、ElseIfは使わずに、Select Caseを好んで使います。
なんとなく見やすいと感じています。
と言いますか、間違いなく見やすいはずです。



同じテーマ「マクロVBA入門」の記事

第19回.総合練習問題1
第20回.条件分岐(IF)
第21回.条件分岐(ElseIf)
第22回.条件分岐(Select Case)
第23回.メッセージボックス(MsgBox関数)
第24回.インプットボックス(InputBox関数)
第25回.名前付き引数について
第26回.総合練習問題2
第27回.ブック・シートの選択(Select,Activate)
第28回.セル・行・列の選択(Select,Activate)
第29回.セル・行・列の削除・挿入(Delete,Insert)


新着記事NEW ・・・新着記事一覧を見る

VBAにおける変数のメモリアドレスについて|VBA技術解説(11月8日)
空文字列の扱い方と処理速度について(""とvbNullString)|VBA技術解説(1月7日)
Errオブジェクトとユーザー定義エラー|VBA入門(11月5日)
シングルクォートの削除とコピー(PrefixCharacter)|VBA技術解説(11月4日)
ユーザー定義型の制限とクラスとの使い分け|VBA技術解説(11月3日)
クリップボードに2次元配列を作成してシートに貼り付ける|VBA技術解説(11月1日)
VBAクラスを使ったイベント作成(Event,RaiseEvent,WithEvents)|VBA技術解説(10月31日)
VBAクラスのAttributeについて(既定メンバーとFor Each)|VBA技術解説(10月19日)
VBAの用語について:ステートメントとは|VBA技術解説(10月16日)
VBAのマルチステートメント(複数のステートメントを同じ行に)|VBA技術解説(10月14日)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数宣言のDimとデータ型|ExcelマクロVBA入門
6.繰り返し処理(For Next)|ExcelマクロVBA入門
7.マクロって何?VBAって何?|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.セルに文字を入れるとは(Range,Value)|VBA入門



  • >
  • >
  • >
  • 条件分岐(Select Case)

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。




    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
    本文下部へ