定数を理解する

今回は定数についてメモしておきます。

ユーザー定義定数


Constステートメントを使い、定数を宣言します。 定数を宣言することで、プログラム内では値ではなく定数で記述することが可能になります。

サンプルプログラムでは、これらが定数で宣言されています。
  • オープンするブックのパス (3行目)
  • 対象となるシート名 (4行目)
  • 取得するセルの行番号 (5行目)
  • 取得するセルの列番号 (6行目)
  • 各種メッセージ (8~10行目)

実行プログラム

対象ブック
実行結果

  • 小文字でも宣言は可能ですが、慣例として大文字で宣言します。
実際のプログラムではコード内に文字列、数値などが直接記述されることはありません。
特にプログラムの中で何度も記述するものは定数にしておきます。

例えばフォーマット変更に伴うセルアドレスの修正が発生した場合、同じセルを何度も記述している場合、記述箇所の分だけ修正しなければなりませんが、サンプルのように定数宣言しておけば宣言箇所を修正するだけで済みます。
修正が容易、且つ、修正漏れの危険性が軽減されます。

保守性という観点からも定数で宣言しておくべきと言えます。



組み込み定数(システム定義定数)


定数には、ユーザーが定義するもの以外にアプリケーションにより提供されているものがあります。
それらが組み込み定数です。
頻繁に使用する数値が存在しますが、数値のままでは覚えにくく、可読性も低くなり保守が困難になります。
定数を使うことで、コード可読性を高め、保守も容易になります。

例えば、次のプログラムではStrConv関数に第2パラメーターとして"32"を渡しています。
しかし、"32"が何を意味するか覚えておくのは大変です。



実行結果


実際に実行してみると、ひらがなに変換されました。
こういう場合の為に用意されているのが、組み込み定数です。 次のプログラムでは”vbHiragana”となっています。
これであれば、意味がわかるので可読性が高まります。
関数ごとに定数を確認してください。