VBA再入門
第2回.マクロを書いて動かす(SubとF5)

マクロが覚えられないという初心者向けに理屈抜きのやさしい解説
最終更新日:2020-09-26

第2回.マクロを書いて動かす(SubとF5)


マクロを実際に書いて動かしてみましょう、
知識の積み上げも必要ですが、それ以上に必要なのが体験の積み上げです、
マクロVBA習得においては、
とにかく書く、
とにかく動かす、
この経験に勝るものはありません。


前回のマクロを書く準備は完了していますよね。
マクロを書こうと思ったら、まず初めにマクロを書く準備をする必要があります。と、その前に、ひとつ説明しておくことがあります。エクセルのマクロとVBAという言葉の意味です。「マクロ」とは、エクセルの操作を自動化するもので、その自動化する機能を「マクロ」と呼びます。

マクロ有効ブックの作成

ではさっそく書いていきましょう。
っと、その前にブックを用意しましょう。

・新規ブックを開いてください。
・新規ブックを名前を付けて保存します。
 ただし、ファイルの種類に気をつけてください。
 必ず、マクロ有効ブックにしてください。
 

Excel ファイルの種類

最初は上のように、Excel ブック(*.xlsx)となっていますが、
これでは、マクロが保存できないのです。

Excel ファイルの種類

拡張子(*.xlsm)の部分は表示されないPCもありますが、特に気にしなくて良いです。
Excel マクロ有効ブック」となっていることを確認してください。

マクロVBAを書いてみる

VBEを起動(開発タブからVisual Basic、Alt + F11)してください。
標準モジュールが挿入してなければ、標準モジュールを挿入して下さい。
標準モジュールを挿入したはずなのに見当たらない場合は、

Excel 標準モジュール

このように、VBEの左上のプロジェクトという部分の一番下に、
標準モジュールがあり、その下に、Module1があれば、標準モジュールは挿入済みなので、
このModule1をダブルクリックしてください。

はい、ではマクロを書きましょう。

Excel サンプル プロシージャー

sub 練習1

と入力し、Enterして下さい。
subは小文字で入力します。
すると、

Excel サンプル プロシージャー

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

これが1つの機能を持ったマクロになります。
SubからEnd Subの間に、やりたいことをマクロの言語であるVBAで書いていきます。
上では何も書いていませんので、マクロの器だけ用意した事になります。
さすがにこれでは、何もしないマクロってことになりますので、何か書き加えてみましょう。

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

Excel サンプル プロシージャー

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

Excel サンプル プロシージャー

msgbox "おはよう"

と入力し、Enterして下さい。
msgboxは小文字で入力します。
すると、

Excel サンプル プロシージャー

このように、
msgboxのmとbが大文字に変わりMsgBoxとなります。

MsgBoxはメッセージボックスといって、MsgBoxに続けて書いた文字を、ポップアップウインドウとして表示するものです。

VBAで使用する単語は、
・英単語をそのまま
・英単語を連結している
・英語の頭文字で略している
ほぼこの3通りおよびその組み合わせになっています。
MsgBoxは、MessageBoxの略になっていますね。

マクロVBAの実行

さて、マクロを書いたら、実行しないと意味がありません。
マクロの実行方法は、
入力カーソル(縦棒の点滅、下の画像では、MsgBoxの下)が、
Sub~End Subの間にある状態で行います。

Excel プロシージャーの実行

挿入の下あたりにある右向き緑の三角アイコン
または、メニューの実行
ショートカットとしてはF5が用意されています。

Excel サンプル

どうですか、
ちゃんとメッセージボックスが表示されたはずです。
メッセージボックスはOKボタンを押して閉じてくださいね。
以上が、マクロを書いて実行する手順です。

複数のマクロVBAを書く

続けて、もう一つマクロを書いてみましょう。

Excel サンプル プロシージャー

練習1の時と同じ手順で書けましたか。

小文字で入力する
subの中は、TABでインデントを付ける


逆に面倒・・・などと思わないでくださいね、
大文字で書こうが、インデントを付けなかろうが、マクロは動きます。
でも、でも、これは絶対に守ってください。
マクロが自在に書けるようになった時、この重要性が分かリます。
それまでは、そのように書くものだと理解してください。

練習1と練習2が出来ましたが、
このように、一つの標準モジュールに複数のマクロが書けます。
いくつでも好きなだけマクロを追加していけます。

プロシージャーとは

マクロという言い方をしてきましたが、VBAでの正式な呼び方としては、
プロシージャーといいます。
呼び方など知らなくてもマクロを書けますが、今後の説明の便宜上必要なので書きました。
今後は、マクロという言い方と、プロシージャーという言い方が混在することもあるかもしれませんが、同じこととしてとらえてください。
1つのマクロの塊をVBAではプロシージャーと呼ぶというだけの事です。

ここでもう少しだけ文法の話をします。
上のマクロで書いた、
練習1や練習2がマクロの名前になります。
この名前の付け方に若干の制限があります。

・使える文字は英数大小文字および全角(漢字も含む)が使えます。
・英記号は_アンダーバーのみ(半角・全角とも)
・先頭に数字は使えない
・一つの標準モジュール内では、同じ名前は付けられない

これだけ覚えておけばOKです。
何より、日本語で書けば、上記の制限はほとんど気にならないはずです。

「マクロを書いて動かす」のまとめ

・標準モジュールを挿入
・sub 名前 ここまで入れたらEnter
・Subの中では、TABキーでインデント
・Sub~End Subの間に入力カーソルを置いて実行F5

ExcelマクロVBA入門の対応ページ

第6回.とにかく書いて見よう(Sub,End Sub)
それでは、とにかく、マクロVBAを書いてみましょう。sub練習1 と入力し、Enterして下さい、このように、subがSubと先頭が大文字になり、後ろに()が付きます。そして、下に、EndSubが追加されます。

第7回.マクロを実行するには(F5)
それでは前回作ったマクロ、「練習1」を実行してみましょう。マクロを実行する方法は、大きく2通りあります、・VBEの画面で実行 ・ワークシートで実行 その時の都合で、どちらで実行しても構いません。ボタンをクリックすることでマクロが自動実行されるのを見たことがあるかもしれません。



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

第1回.マクロを書く準備をする(VBAとVBE)
第2回.マクロを書いて動かす(SubとF5)
第3回.セルに数字や文字を入れる(RnageとCells)
第4回.セルの値を使って計算する(四則演算)
第5回.同じ計算を行数分繰り返す(For~Next)
第6回.表の先頭から最終行まで繰り返す(ForとEnd(xlUp).Row)
第7回.セルの値によって計算を変える(Ifステートメント)
第8回.表範囲をまとめて消去する(OffsetとClearContents)
第9回.関数という便利な道具(VBA関数)
第10回.ワークシートの関数を使う(WorksheetFunction)
第11回.分からない事はエクセルに聞く(マクロの記録)


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

VBA100本ノック 18本目:名前定義の削除|VBA練習問題100(11月6日)
VBA100本ノック 17本目:重複削除(ユニーク化)|VBA練習問題100(11月6日)
VBA100本ノック 16本目:無駄な改行を削除|VBA練習問題100(11月5日)
VBA100本ノック 15本目:シートの並べ替え|VBA練習問題100(11月4日)
VBA100本ノック 14本目:社外秘シート削除|VBA練習問題100(11月3日)
VBA100本ノック 13本目:文字列の部分フォント|VBA練習問題100(11月1日)
VBA100本ノック 12本目:セル結合を解除|VBA練習問題100(10月31日)
VBA100本ノック 11本目:セル結合の警告|VBA練習問題100(10月30日)
VBA100本ノック 10本目:行の削除|VBA練習問題100(10月29日)
VBA100本ノック 9本目:フィルターコピー|VBA練習問題100(10月28日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.マクロって何?VBAって何?|VBA入門
6.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.マクロはどこに書くの(VBEの起動)|VBA入門




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


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



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