VBA技術解説
実は奥が深いIfステートメント

ExcelマクロVBAの問題点と解決策、VBAの技術的解説
公開日:2013年5月以前 最終更新日:2020-05-17

実は奥が深いIfステートメント


プログラムと言うものは、
条件により処理を分ける。
これにつきます。


つまり、この条件が一番問題となります。
そして、その記述をするものが、
Ifステートメントになります。

IFステートメントの基本

まずはIFステートメントの基本を確認しましょう。

If 条件式 Then
  '条件式が真(True)の場合の処理
Else
  '条件式が偽(False)の場合の処理
End If

条件式は、 真(True)か偽(False)を評価する数式または文字列式を指定します。
例えば、

If A = B Then
  'A = B の場合の処理
Else
  'A <> B の場合の処理
End If

ここでの、A = Bは、真(True)か偽(False)を返します。
その結果が、
TrueならThen以下を処理します。
FalseならElse以下を処理します。

IFステートメントの詳細については以下を参照してください。
第20回.条件分岐(If)
・Ifステートメントの構文 ・IFステートメントの条件式 ・Ifステートメントの使用例文 ・Ifステートメントのネスト(入れ子) ・サイト内のIfステートメント参考ページ ・最後に
第21回.条件分岐(ElseIf)
前回のIFステートメントでは、真か偽の二択でした。今回は、もっと多くの分岐が必要な、Ifステートメントで多肢条件分岐の場合の書き方です。ステートメントとしては、Ifステートメントです。IfステートメントのElseIfの構文 If条件式1Then 条件式1が真の処理 [ElseIf条件式2Then 条件式2が真の処理…
第22回.条件分岐(Select Case)
・Select Caseステートメントの構文 ・Select Case の例文 ・Select Case の応用

IFステートメントのいろいろな書き方

以下のように、ブール型変数(Boolean)の判定を考えてみましょう。
・データ型 ・変数の使い方 ・変数名の規則 ・良く使われる変数名 ・自動型変換、暗黙の型変換 ・変数宣言の必要性 ・Dim変数宣言のまとめ

Dim A As Boolean
'・・・
If A = True Then
  A = True の場合の処理
Else
  A = False の場合の処理
End If

特に問題はなさそうですが、

If A = True Then

実はこれは、無駄な記述とも言えます。
もっと省略して書くことができます。
AはTrueかFalseな訳ですから、

If A Then

これだけでも良いのです。
例えば、よくあるのは

If IsNumeric(A) = True Then

IsNumericは、True/Falseを返す関数です。
つまり、IsNumeric(A)は真(True)か偽(False)しか返しませんので、

 If IsNumeric(A) Then

これだけで良い事になります。
もちろん、 = True を書いても問題ないですし、
むしろ、初心者には= True を書いた方が解り易いかもしれません。

では、否定形、つまり数値以外の場合はどうでしょうか。

If IsNumeric(A) <> True Then

これでも良いのですが、
<> True
これは
= False
ですね。

If IsNumeric(A) = False Then

Not演算子 を使って、

If Not IsNumeric(A) Then

このように書いた方が、英文っぽくて格好よくいかもしれません(笑)
上記の場合は、どちらを書いても良いと思います。
むしろ無理に否定形にしないで、

If IsNumeric(A) Then
Else
  '・・・
End If

このようにElseに記述した方が理解しやすい場合も多いです。
例えば、
条件式が複雑な場合に無理に否定形を作ろうとして、かえって間違った条件式にしてしまう事もありえます。

ようは、同じ条件の書き方でも、何通りも書き方があるという点です。
では、どのような書き方が良いかというと、

読みやすい
解り易い


これにつきます。
そして、読みやすい・解り易い 、これは人により違ってきますし、
何より、単純にVBA記述だけでは何が良いかは断定できない場合も多いものです。
その条件が出てきた背景や、VBAを共有する人たちの共通認識等々、これらによって変わってくるものです。
つまり、読みやすい・解り易い 、これらは時と場合によって変わってきます。

まずは、自身にとってにとって、読みやすい・解り易い、これが一番良いでしょう。
そして次には、VBAを共有する人たちにとって、読みやすい・解り易い、そのようなVBAを書くようにしていきましょう。



同じテーマ「マクロVBA技術解説」の記事

プログラミングの基本~ロジックの組み立て
実は奥が深いIfステートメント
論理積(And)論理和(Or)と真(True)偽(False)の判定
If条件式のいろいろな書き方:TrueとFalseの判定とは
VBAでの括弧()の使い方、括弧が必要な場合
VBAにおけるピリオドとカンマとスペースの使い方
変数とプロシージャーの命名について
文字列置換の基本と応用(Replace)
データクレンジングと名寄せ
ForとIfのネストこそがVBAの要点


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

第5章:AI×VBAでつまづかない!トラブルシューティングとAIとの付き合い方 |生成AI活用研究(2025-05-20)
第4章:【事例で学ぶ】AIとVBAでExcel作業を劇的に効率化する! |生成AI活用研究(2025-05-20)
第3章:AIを「自分だけのVBA先生」にする!質問・相談の超実践テクニック|生成AI活用研究(2025-05-19)
第2章 VBAって怖くない!Excelを「言葉で動かす」(超入門)|生成AI活用研究(2025-05-18)
第1章:AIって一体何?あなたのExcel作業をどう変える?(AI超基本)|生成AI活用研究(2025-05-18)
AI時代のExcel革命:AI×VBAで“書かない自動化”超入門|生成AI活用研究(2025-05-17)
Geminiと100本ノック 23本目:シート構成の一致確認|生成AI活用研究(5月16日)
AIが問う出版の未来は淘汰か進化か:AIと書籍の共存の道とは|生成AI活用研究(2025-05-16)
Geminiと100本ノック 22本目:FizzBuzz発展問題|生成AI活用研究(5月15日)
すぐに使える!生成AI プロンプト作成 実践ガイド|生成AI活用研究(2025-05-15)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.繰り返し処理(For Next)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.ひらがな⇔カタカナの変換|エクセル基本操作
6.RangeとCellsの使い方|VBA入門
7.メッセージボックス(MsgBox関数)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.FILTER関数(範囲をフィルター処理)|エクセル入門
10.条件分岐(Select Case)|VBA入門




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


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



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