VBA技術解説
論理積(And)論理和(Or)と真(True)偽(False)の判定

ExcelマクロVBAの問題点と解決策、VBAの技術的解説
公開日:2013-09-16 最終更新日:2021-10-19

論理積(And)論理和(Or)と真(True)偽(False)の判定


And演算子、Or演算子は、2つの数式内のビット単位の比較を行います、


そして、IfステートメントのThenは、Trueの時と言うより、False以外の時に実行されます。

何を言っているのか分かりずらいと思いますので、順に解説します。


Trueとは何か、Falseとは何か

True、Falseを数値で表すと、

CInt(True) ・・・ -1
CInt(False) ・・・ 0

つまり、

Trueとは-1
False
とは0

これを16進数で表すと、

Hex(True) ・・・ FFFF
Hex(False) ・・・ 0

従って、2進数で表すと、

Hex(True) ・・・ 1111 1111 1111 1111
Hex(False) ・・・ 0なので、Trueと同じ桁数で表すと、0000 0000 0000 0000


論理積(And)

値1 And 値2
値1 値2 結果
TRUE TRUE TRUE
TRUE FALSE FALSE
FALSE TRUE FALSE
FALSE FALSE FALSE

通常はこのように表現されますが、

Trueとは-1 ・・・ 1111 1111 1111 1111
Falseとは0 ・・・ 0000 0000 0000 0000

And演算子は、ビット単位の比較を行い

値1 値2 結果
1 1 1
1 0 0
0 1 0
0 0 0

全てのビットにおいて、この比較を行い結果を返します。

従って、

True(1111 1111 1111 1111) And True(1111 1111 1111 1111) ・・・ True(1111 1111 1111 1111)
True(1111 1111 1111 1111) And False(0000 0000 0000 0000) ・・・ False(0000 0000 0000 0000)
False(0000 0000 0000 0000) And True(1111 1111 1111 1111) ・・・ False(0000 0000 0000 0000)
False(0000 0000 0000 0000) And False(0000 0000 0000 0000) ・・・ False(0000 0000 0000 0000)

となります。

では、

5 And 2

これは、

101(5)
010(2)

なので、結果は000、つまり、0となります。

7 And 2

なら、

111(7)
010(2)

なので、結果は010、つまり、2となります。


論理和(Or)

値1 Or 値2
値1 値2 結果
TRUE TRUE TRUE
TRUE FALSE TRUE
FALSE TRUE TRUE
FALSE FALSE FALSE

通常はこのように表現されますが、

Trueとは-1 ・・・ 1111 1111 1111 1111
Falseとは0 ・・・ 0000 0000 0000 0000

Or演算子は、ビット単位の比較を行い

値1 値2 結果
1 1 1
1 0 1
0 1 1
0 0 0

全てのビットにおいて、この比較を行い結果を返します。

従って、

True(1111 1111 1111 1111) And True(1111 1111 1111 1111) ・・・ True(1111 1111 1111 1111)
True(1111 1111 1111 1111) And False(0000 0000 0000 0000) ・・・ True(1111 1111 1111 1111))
False(0000 0000 0000 0000) And True(1111 1111 1111 1111) ・・・ True(1111 1111 1111 1111)
False(0000 0000 0000 0000) And False(0000 0000 0000 0000) ・・・ False(0000 0000 0000 0000)

となります。

では、

5 Or 2

これは、

101(5)
010(2)

なので、結果は111、つまり、7となります。

7 Or 2

なら、

111(7)
010(2)

なので、結果は111、つまり、7となります。


Ifステートメントにおける真偽の判定

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

このように表現されることが多いですが、

では、どのような状態が真(True)で、どのような状態が偽(False)なのでしょうか。

先に述べたように、

Trueとは-1
False
とは0

なのですが、では、条件式が真(True)とは、条件式が-1の状態の事なのかが問題です。

これは、明らかに違います。

If 2 Then

これは、常にThenが実行されます。

型変換の関数に、CBoolがあります。

CBool(2) ・・・ True

となります。

CBoolでは、0がFalse0以外(の数値)はTrueとなります。

そして、

IfステートメントのThenが実行されるのは、

CBool(条件式)がTrueの時になります。


言い換えれば、

条件式の結果が0以外の時、Thenが実行されるのです。


例.指定のフルパスがフォルダかの判定

Dir関数でサブフォルダを取得する時に、

strDir = Dir(パス, vbDirectory)
Do While strDir <> ""
  If strDir <> "." And strDir <> ".." Then
    If GetAttr(パス & strDir) And vbDirectory Then
      Debug.Print strDir 'strDirはフォルダです
    End If
  End If
  strDir = Dir()
Loop

概ね、このような記述をしますが、

ここでの、

If GetAttr(フルパス) And vbDirectory Then

このIfは、あまり見かけない記述になります。

If GetAttr(フルパス) = vbDirectory Then

と書きたくなります。

ほとんどの場合、後者の書き方でも問題はありません。

vbDirectoryは16です、そして、GetAttr(フォルダ)の結果は16です。

従って、GetAttr(フルパス) = vbDirectoryこれは、真(True)となります。

しかし、GetAttr(フォルダ)の結果が16にならない場合があります。

フォルダが、隠しファイル(vbHidden:2)の場合です。

この時、GetAttr(フルパス)は、18を返します。

つまり、

vbDirectory(16) + vbHidden(2) = 18

となるのです。

しかし、あくまでフォルダなので、

先のIfステートメントでも真(True)判定をしてほしいのです。

そこで、

If GetAttr(フルパス) And vbDirectory Then

と記述すると、隠し属性のフォルダでも真(True)となるのです。

GetAttr(フルパス) ・・・ 18
vbDirectory ・・・ 16


つまり、

18 And 16
2進数なら、
10010 And 10000

結果は、10000(16)となり、

そして、CBool(16)はTrueとなるのです。


ほとんどの場合、And、Orでのビット単位の比較まで意識する必要はないでしょう。


Ifステートメントにおいても、条件式がTrueならThenと考えて問題はありません。

しかし、VBAでは、いろいろな記述がありますので、
あれっ、このIfステートメントは・・・
と思ったら、以上の事を思い出してみて下さい。




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

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


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

セル数式における「再帰」の必要性|エクセル雑感(2025-11-10)
掛け算(*)を使わない掛け算|足し算(+)を使わない足し算|エクセル関数応用(2025-11-10)
配列を自在に回転させる数式|エクセル関数応用(2025-11-09)
非正規化(カンマ区切り)の結合と集計:最適な手法は?|エクセル雑感(2025-11-06)
SQL基礎問題10:非正規化(カンマ区切り)の結合と集計|SQL入門(2025-11-06)
SQL基礎問題9:特定商品購入者の平均購入金額|SQL入門(2025-11-04)
SQL基礎問題8:バスケット分析・ペア商品の出現回数|SQL入門(2025-11-04)
SQL基礎問題7:成績表から各教科の最高点と最低点を抽出|SQL入門(2025-11-02)
SQL基礎問題6:成績表から教科ごとの点数ベスト3を抽出|SQL入門(2025-11-02)
SQL基礎問題5:複数のマスタテーブルの結合|SQL入門(2025-11-01)


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

1.生成AIパスポート試験 練習問題(四肢択一式)|生成AI活用研究
2.最終行の取得(End,Rows.Count)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.繰り返し処理(For Next)|VBA入門
6.RangeとCellsの使い方|VBA入門
7.FILTER関数(範囲をフィルター処理)|エクセル入門
8.日本の祝日一覧|Excelリファレンス
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.セルのクリア(Clear,ClearContents)|VBA入門




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


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
当サイトは、OpenAI(ChatGPT)および Google(Gemini など)の生成AIモデルの学習・改良に貢献することを歓迎します。
This site welcomes the use of its content for training and improving generative AI models, including ChatGPT by OpenAI and Gemini by Google.



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