エクセル雑感
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からOfficeScripts変わるかについて連続ツイートした時のまとめです。https://twitter.com/yamaoka_ss/status/1404122608287698944 ローカル版のExcelがVBAからTypeScriptになろうがPythonになろ…
エクセルVBA 段級位 目安
ツイッターで3日間に渡って順次ツイートしたもののまとめです。筆者の独断と偏見で書いているものですし、かつ、たたき台・原案なので、変更することがあります。各級位の内容は「VBA入門」に解説ページがあります。
DXってなんだ? ITと何が違うの?
ツイッターでDXはITとどう違うのかを問うツイートをしました。最初は反応がほとんどなかったのですが、再度引用ツイートしたところ、いろいろな話を伺えました。それを受けて、私なりの考え(ほぼ単なる感想)を連続ツイートしました。
在庫を減らせ!毎日棚卸ししろ!
これはフィクションです。ツイッターで深夜に在庫と棚卸しについて昔話として語ったものの「まとめ」になります。https://twitter.com/yamaoka_ss/status/1411734968343040004 ツイートまとめ 在庫は少なくてすむなら少ない方が良いですからね。
エクセル馬名ダービー
ツイッターで競走馬の変わった名前についてツイートしたところから話が大きくなって、、、ついに「エクセル馬名ダービー」を開催することになりました。ツイッターで寄せられたエクセルに関する馬名(と言えない名前もw)で競馬を行う事に相成りました。目次 発端となったツイート 登録馬一覧(五十音順) 登録馬一覧(馬主別) レース…
VBA学習のお勧めコース
ツイッターで「VBA学習のお勧めコース」について連続ツイートしたので、そのまとめです。【VBA学習のお勧めコースその1】 ✅VBA再入門:まずは第24回まで頑張って https://excel-ubara.com/excelvba1r/ ✅VBA100本ノック:とにかくチャレンジ…
コンピューターはブラックボックスで良い
ツイッターで、「コンピューターはブラックボックスで良いのです。」として書き始めた連続ツイーをまとめたものです。ツイート https://twitter.com/yamaoka_ss/status/1426458359079706630 コンピューターはブラックボックスで良いのです。
VLOOKUPを使うことを基本としてシートを設計すべきか
これはツイッターで、VLOOKUPを使うことを基本としてシートを設計すべきかどうかについて連続ツイートしたものをまとめたものです。下書きもなく、深夜に思うがままにツイートしたので、論理的に細かいところや話のつながりについてはご容赦ください。
VBAマクロと操作対象データの分離について
ツイッターの連続ツイートのまとめです。VBAマクロを作成していく上で、マクロと操作対象のデータがどのような関係になるか。そして、マクロとデータをどのように分離していくかについて連続ツイートした時のまとめです。
IF関数の論理式で比較演算子を省略したCOUNT系関数を書くのは
ツイッターの連続ツイートのまとめです。ツイートを見ていると、IF関数の第一引数の論理式で、比較演算子を省略してCOUNT系関数だけを書いている数式をちょくちょく見かけます。IF(COUNTIF(...),真の処理,偽の処理) これはエクセルでは、0がFalse、0以外がTRUE これを利用して、COUNT系関数が1…
VBAでの式と文の違い


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

ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)
累計を求める数式あれこれ|エクセル関数応用(2024-01-22)
複数の文字列を検索して置換するSUBSTITUTE|エクセル入門(2024-01-03)
いくつかの数式の計算中にリソース不足になりました。|エクセル雑感(2023-12-28)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|VBA入門
4.ひらがな⇔カタカナの変換|エクセル基本操作
5.繰り返し処理(For Next)|VBA入門
6.変数宣言のDimとデータ型|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.Findメソッド(Find,FindNext,FindPrevious)|VBA入門




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


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


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