skillup

技術ブログ

プログラミング全般

ExcelVBAに関して(主にプロシージャ)

投稿日:

いつも半年ごとぐらいに触っていてあまり知識が蓄積しないので(汗)これを機につまづいたところをちょっとメモ。

基本

基本的な変数の代入や条件分岐、ループなどはあまり迷わないのでちょっと省略させていただきます。主にプロシージャ関連について。

ExcelVBAでは基本的にプロシージャという単位で処理を呼び出します。プロシージャの塊がモジュールです。

JavaやPHPでたとえるとプロシージャ=メソッド、モジュール=クラスみたいなものっぽいです。

また変数の定義はDim 変数名 as 型で表記。通常通り、データをいれてあげればOKですが、オブジェクト(よく使いそうだなーと思うのはコレクション)は動きが若干異なり、Set コレクション = new Collectionが必要になります。

ちなみにすべてのプロシージャの上に変数を置くとグローバルな変数(or 定数になります。)

ちなみに外部からプロシージャを呼び出したいときは下記のようにCallをつけて呼び出します。※つけなくても呼べるようですがわかりやすさのためにつけたほうがいいようです。

呼び出される側は変数を定義し、値渡しか参照渡しかを定義できます。

ちなみに戻り値がほしい場合はモジュールをFunctionプロシージャにする必要があります。

またメソッドの最後にプロシージャの名前 = 対象の変数としなければいけません。またオブジェクトの場合は戻り値を取得するときもSet ~というメソッドが必要になります。

オブジェクトでなければSetという文字は必要ありません。

メモ

  • 開発画面でモジュールの部分でカーソルが当たっているときに実行を押すとその部分のモジュールのテストが始まる。モジュールごとにテストができる点はかなりありがたいですね。
  • まだあまり使っていませんが、ブレークポイントを使ったステップ実行やウォッチウィンドウ(特定の変数を監視して値を出力してくれる)はデバッグにかなり使えそうです。
  • オブジェクトの使い方にかなり癖があり、ここが結構ハマりました。ここは最初、ちょっと難所かと思います。
  • ちなみにデバッグは直接Cellに出してあげてもいいですが、Debug.Printを使ってイミディエイトウィンドウを使っても観ることができます。

参考リンク

昨日までJavaJavaしてた人がいきなりExcelのVBAを実装する羽目になったときのためのメモ

タイトルからはわかりにくいですが、まとめてきな記事で必要なことがほぼ網羅されてます。

-プログラミング全般

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

シェル基礎2

シェルコマンド使い始めて数年たちますが、いまだに知らないことはおおいですし、早く知っとけばよかった的なこともたくさんあります。 そんな小ネタ集を alias よく使うコマンドを別名で登録することができ …

no image

オブジェクト指向 クラスの設計と業務ロジックの整理

本日も引き続き「現場で役立つシステム設計の原則」を読み進めてます。 本日は主にクラスの作り方について。 Contents1 クラス設計と業務ロジック1.1 要点1.2 感想 クラス設計と業務ロジック …

no image

コードの抽象化

リーダブルコードも終盤に少しずつ近づいてきました。 今まではどちらかというとコードの点や線の技術に注目してきましたが、これからは面的な要素に注目していきます。 リーダブルコードでは「無関係の下位問題を …

no image

調査スキルについて

本日は実務でとても大切な不具合の発見方法について 通常のプログラマとして仕事をしておりますと、通常の実装よりは不具合時の調査のほうが難しいことが多々あります。 もちろんものによるんですが、経験のある人 …

no image

オブジェクト指向 値オブジェクトの活用と場合分けに関して

オブジェクト指向 その1 オブジェクト指向 その2 オブジェクト指向 その3 でオブジェクト指向に触れたんですが、基本から勉強しなおす必要があると思い、まとめ&追記 参考文献 現場で役に立つシステム設 …