エクセル雑感
VBAでの式と文の違い

ExcelマクロVBAとエクセル関数についての私的雑感
公開日:2022-10-01 最終更新日:2022-10-02

VBAでの式と文の違い


ツイッターで投票を行い、その後に解説したものです。


式とは文とは
式と文の違いについての解説です。


投票ツイート


VBA 式とは 文とは
https://twitter.com/yamaoka_ss/status/1575865356924526592

式と文
改めて聞かれると説明が大変ですよね。
あまり意識することも無いと思います。
ではここで投票です。
VBAです。
Dim x, y
x = y
この「x = y」これは何?

・式
・文
・式でも文でもない
・にゃんともいえない


式と文の違いについて

この問いの答えは非常に微妙な部分があります。
そもそもこの用語は厳密に定義されているのかもはっはりしません。
したがって、現時点での私の解釈だという事を理解しておいてください。
ただし、一般的にVBA(VB.NETも)では概ねこの解釈で良いと思っています。


ではまずは結論から、
これは、
「文」です。
「代入文」です。
最初にウィキペディアの「式 (プログラミング)」から
https://ja.wikipedia.org/wiki/%E5%BC%8F_(%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0)
>C#においては代入は式であるが、同じ.NET系言語であるVB.NETでは代入は文である。
このように書かれています。(詳細はwikiで)


私もこの通りだと思っています。
VBAにおいて先の
x = y
これは
Let x = y
この省略であり、代入文です。
Debug.Print x = y
If x = y Then
これらの「x = y」は「式」です。条件式ですね。
式は評価され値を返します。
Let x = y
この「x = y」は値を返しません。


恐らくここまでは、どのような用語を使うかと言うだけで大した異論はないと思います。
ですがVBAでは1つ問題があって、
「オブジェクト式」と言う言葉があります。
私はずっとこの用語を使っていなかったのですが、超有名な複数サイトでこの用語が使われています。
これは式なのか…


用語は統一したほうが良いので後年に「オブジェクト式」として説明ページを追加しました。
オブジェクト.プロパティ
オブジェクト.メソッド
このようなものを「オブジェクト式」と呼んでいます。
しかしこれは「式」と読んで良いのかが疑問です。(自分でも解説ページ書いといて、何ですけど😅)


プロパティは値を返しますが少し話が違います。
Let 式 = 値
Call 式
「式」に値を入れたり、式をCallするというのは違和感があります。
ではなんと呼ぶか…
そうなんです、困りますよね😅
したがって、私もとりあえず割と広く使われている用語のようなので「オブジェクト式」として解説しています。


そもそもドット(.)これも何と呼ぶのかはっきりしません。
メンバーアクセス演算子
ドット(.)演算子
VBとしてはこのように呼ばれますが、VBAのページでは明確に記述されているものを見た覚えがありません。
(どこかにあるかもしれませんが)


細かい話もありますが、厳密に区別しても大した意味もありません。
VBAでは、
「式」は何らかの値を返すと考えれば良いと思います。
したがって値を返さない、
x = y
この代入は式ではなく代入文と呼ぶべきもでのす。
ただしyには値または式が書けますので、
x = y * z
この「y * z」これは式です。


追記
つまり、これ(添付)で「文」だという事です。
Letでの「=」は代入文の必須の構成要素です。
If … Then、このThenと同様です。
VBAではIfは「文」であり「式」とは呼ばない(事が多い)。
同様に「代入文」と呼ぶ。と言うのが私の見解です。
https://learn.microsoft.com/ja-jp/office/vba/language/reference/user-interface-help/let-statement

VBA 式とは 文とは




同じテーマ「エクセル雑感」の記事

ローカル版エクセルが「Office Scripts」に変わる日
エクセルVBA 段級位 目安
DXってなんだ? ITと何が違うの?
在庫を減らせ!毎日棚卸ししろ!
エクセル馬名ダービー
VBA学習のお勧めコース
コンピューターはブラックボックスで良い
VLOOKUPを使うことを基本としてシートを設計すべきか
VBAマクロと操作対象データの分離について
IF関数の論理式で比較演算子を省略したCOUNT系関数を書くのは
VBAでの式と文の違い


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

付録:AI×VBA実践リソース集|生成AI活用研究(2025-05-25)
おわりに:AI×VBAはあなたの未来を変える強力な武器|生成AI活用研究(2025-05-25)
第7章:さらなる高みへ!AI×VBA応用テクニックと未来への備え|生成AI活用研究(2025-05-24)
第6章:AIとVBAを学び続ける!あなたの「超効率化」を止めないヒント|生成AI活用研究(2025-05-22)
第5章:AI×VBAでつまづかない!トラブルシューティングとAIとの付き合い方 |生成AI活用研究(2025-05-21)
第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)


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

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」をお願いいたします。
本文下部へ