ツイッター出題回答
VBAでの式と文の違い

ExcelマクロVBAとエクセル関数についての私的雑感
最終更新日: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 ・・・新着記事一覧を見る

ByRef引数の型が一致しません。|ツイッター出題回答 (2023-09-22)
シートコピー後のアクティブシートは何か|ツイッター出題回答 (2023-09-19)
Excel関数の引数を省略した場合について|ツイッター出題回答 (2023-09-14)
セル個数を返すRange.CountLargeプロパティとは|VBA技術解説(2023-09-08)
記号を繰り返してグラフ作成(10単位で折り返す)|ツイッター出題回答 (2023-08-28)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-08-24)
ランクによりボイントを付ける(同順位はポイントを分割)|ツイッター出題回答 (2023-08-22)
OneDrive使用時のThisWorkbook.Pathの扱い方|VBA技術解説(2023-07-26)
列幅不足による###表示や指数表示を判定する|VBA技術解説(2023-07-12)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-07-04)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロとは?VBAとは?VBAでできること|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.条件分岐(IF)|VBA入門




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

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



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