VBA入門
とにかく書いてみよう(Sub,End Sub)

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日:2021-08-10

第6回.とにかく書いてみよう(Sub,End Sub)


それでは、とにかくマクロVBAを書いてみましょう。



VBEで実際にマクロを書いてみましょう

マクロVBA エクセルExcel

VBE(Visual Basic Editor)に標準モジュールを追加したら、そこにマクロを書いていきます。

マクロVBA エクセルExcel

sub 練習1

と入力し、Enterして下さい、

マクロVBA エクセルExcel

このように、subSubと先頭が大文字になり、後ろに()が付きます。
そして、1行空けてその下に、End Subが追加されます。

この、SubからEnd Subまでがマクロです。
1つの機能を持った1つのマクロになります。

VBAでは、この1つのマクロをプロシージャーと言います。

練習1
これがマクロの名前、つまりプロシージャー名です。
プロシージャーの詳細については後述します。

SubからEnd Subの間に、いろいろと処理内容を書き込みます。
上の例では何も中身を書いていませんので、マクロの器だけ用意した何もしないマクロという事になります。

Subの中に何かを書くときは、1段さげて書きます、インデントと言います。
それには、「TAB」キーを押します。
「TAB」キーは(大抵のPCでは)キーボードの一番左の上から3番目です。
マクロVBA エクセルExcel

マクロVBA エクセルExcel

このように、「TAB」キーを押すことで、半角4文字分下がった(右にずれた)状態になります。

では、少し書き加えてみましょう。

その前に、今後の説明として、
マクロの記述部分は、以下のように枠で囲った中に表示します。
表示しているページの他の説明文と区別しやすいようにです。

Sub 練習1()
  Range("A1") = "おはよう!"
End Sub



これは、ワークシートのA列1行のセルに、「おはよう!」という文字を入れるマクロになります。

タイピングする時は、基本的には全て小文字で入力します。

マクロVBA エクセルExcel

=の前後も続けて入力して構いません。
そして、Enterすると、

マクロVBA エクセルExcel

このように、
rangeRangeと、先頭が大文字に変換されます。
これは、Rangeが正しい記述であり、自動で変換されたという事です。
しかし、スペルが間違っていて、rengeと入れていれば、大文字には変換されません。
そこで、タイピングする時は小文字で入力します。
これは、タイピングの手間の問題もありますし、スペルミスに気付きやすくなる利点があります。

ただし、ダブルクォーテーションの中は、固定文字なので変換はされません。
"a1"と入力しても、"A1"とは変換されません。
このA1はセル番地なので、
シート上の関数と同じ見た目になるように大文字で入れる事をお勧めします。

また、=の前後には、自動で半角空白が空いて見やすく整形されます。
=の前後は、半角空白を特に入力する必要はありません。
もちろん=の前後に半角空白を入力しても問題ありません。


プロシージャーについて

プロシージャーは、同じ標準モジュールに複数書くことができます。
複数のプロシージャーを書くとなると同じ名前では区別がつかなくなりますし、そもそも名前は何でも良いという訳にはいきません。
プロシージャー名の付け方にはいくつかの制限があります。

✅英数字(全角半角)、漢字、記号はアンダーバー(_)だけ使える、空白(スペース)は使えない
✅先頭には、数字やアンダーバー(_)は使えない、英文字か漢字で始める
✅使えない予約語(VBAが特別に使っている単語)がある
✅長さは半角で255文字まで
✅1つの標準モジュール内では、同じ名前は付けられない

「予約語」といったものもあり難しく感じてしまうかもしれません。
ですが、予約語を使ったり規則に反する場合は赤字でエラーになりますので、絶対に覚えなければVBAを書けないという事ではありませんので安心してください。

また、漢字を使って日本語で書けば上記の制限はほとんど気にならないはずです。
漢字を使う事を否定する意見もありますが、VBAでは特に気にする必要はないでしょう。
自分自身で分かり易い名前を付けてください。




同じテーマ「マクロVBA入門」の記事

第3回.マクロの記録
第4回.マクロはどこに書くの(VBEの起動)
第5回.VBEのオプション設定(Option Explicit)
第6回.とにかく書いてみよう(Sub,End Sub)
第7回.マクロを実行するには(F5)
第8回.セルに文字を入れるとは(RangeオブジェクトのValueプロパティ)
第9回.Rangeでのセルの指定方法
第10回.Range以外の指定方法(Cells,Rows,Columns)
第11回.RangeとCellsの使い方
第38回.セルに計算式を設定(Formula)
第12回.変数宣言のDimとデータ型


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

抜けている数値を探せ|エクセル雑感(2022-07-01)
.Net FrameworkのSystem.Collectionsを利用|VBA技術解説(2022-06-29)
迷路ネコが影分身の術を体得したら…|エクセル雑感(2022-06-27)
迷路にネコが挑戦したら、どうなるかな…|エクセル雑感(2022-06-26)
サロゲートペアに対応した自作関数(Len,Left,Mid,Right)|エクセル雑感(2022-06-24)
「マクロの登録」で登録できないプロシージャーは?|エクセル雑感(2022-06-23)
オブジェクトのByRef、ByVal、Variant|エクセル雑感(2022-06-22)
コメントから特定形式の年月を取り出す|エクセル雑感(2022-06-19)
4,9を使わない連番作成|エクセル雑感(2022-06-17)
連番を折り返して出力|エクセル雑感(2022-06-16)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.マクロって何?VBAって何?|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.エクセルVBAでのシート指定方法|VBA技術解説




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


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



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