2
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

上級者を目指すExcelVBA #6 『ネーミングルール』

Last updated at Posted at 2022-10-26

変数名や定数名、関数名を付けるときは、一貫したルールで名前を付けましょう。

適当に名前を付けた場合、定数と変数の区別がつかなかったり、変数のスコープがどこまでなのか分からなかったりします。

良くない例

良いネーミングルール

良いネーミングルールの例は以下の通りです。

良いネーミングルールの例
・一目で定数、変数が区別できる
・一目で変数のスコープが判別できる
・名前から関数の処理内容、変数の内容が推測できる
・日本語、数字が使われていない
・一貫性がある

VBAには公式のコーディング規約がないため、他言語のネーミングルールを参考にしつつ、自分の中で一貫したルールを作ると良いかと思います。

 

定数名

定数名の付け方の例
・大文字とアンダーバーのみで記述
・定数の意味がハッキリわかる名前を付ける

定数は他の言語のルールに倣い、大文字とアンダーバーを使って記述します。
スコープを気にする必要性が薄いため、Publicのありなしに関わらず、同じルールで良いと思います。

' API URL
Const TARGET_API_URL = "http://test.com/"

' URLをエンコードするか
Public Const HAS_TO_ENCODE_URL = True

 

変数のスコープ

VBAの変数には以下のスコープが存在します。

  • ローカル変数 (関数の中で定義する変数。プロシージャレベル変数とも)
  • モジュール変数 (関数の外でDim、Privateで定義する変数。モジュールレベル変数とも)
  • グローバル変数(Publicで定義する変数。パブリック変数とも)

コーディング時には変数のスコープを気にする必要があるため、ローカル変数、モジュール変数が一目で区別できる名前を付けます。

なお、Publicで記述するグローバル変数は基本的にクラス以外では使用してはいけません。
これについては別記事で記述します。

 

ローカル変数

ローカル変数名の付け方の例
・先頭は小文字
・シンプルで簡略化した名前を付ける

関数の中で定義するローカル変数は使われる範囲が小さいため、短め、かつ意味が分かる名前を付けます。

【例】
・dName(フォルダ名)
・uName(ユーザ名)
・ptn(正規表現パターン)

短い名前にするのは一目でモジュール変数と区別するため、かつコードをスッキリさせるためです。
毎回変数に長い名前を付けてしまうとコードがゴチャゴチャしてしまいます。
 

モジュール変数

モジュール変数名の付け方の例
・先頭は大文字
・変数の用途が推測できる、やや長めの名前を付ける

こちらはローカル変数と違い、やや長め、かつハッキリと意味が推測できる名前を付けます。

【例】
・DirName(フォルダ名)
・UserName(ユーザ名)
・RegPtn(正規表現パターン)
 

配列・連想配列

配列、コレクション名の付け方の例
・末尾にsを付ける

配列やコレクションの名前は上記のルールに「s」を付けて、複数形にすると良いかと思います。

【例】
・DirNames(フォルダ名の配列、コレクション)
・uNames (ユーザ名の配列、コレクション)

末尾に「Array」、「Col」、「List」などを付ける方もいますが、私は採用していません。
配列やコレクションは非常に使用頻度が高いため、長い名前の変数名が量産されてしまって読みづらくなるためです。

ただし、連想配列(辞書型)の場合は明確に配列と区別するため、末尾に「Dict」などを付けても良いかと思います。

【例】
・DirNamesDict(フォルダ名の連想配列)
・uDict(ユーザ名の連想配列)

 

関数名

関数名の付け方の例
・グローバル関数、ローカル関数共に、処理内容が推測できる長めの名前を付ける
・動詞、または動詞+名詞にする

関数名は処理内容の意味がハッキリと分かるものを付けます。

【例】
・readTextFile(テキストファイル読込用関数)
・convertCSVToJson(CSVからJSONに変換する関数)

先頭の大文字、小文字でグローバル関数とローカル関数の区別を付けても良いと思いますが、変数と違って同じルールにしても良いかと思います。
私は両者で同じルールを採用しています。

その代わり、他モジュールからグローバル関数を呼び出す際は、モジュール名を先頭に付けるようにします。
以下のように、どのモジュールの関数を呼び出しているかハッキリ分かるようにします。

 

Sample.bas
' 他モジュールの関数呼び出し
val = WeatherDataFetcher.getData()

' 自モジュールの関数呼び出し
val = encodeByJson(val)

 

モジュール名

モジュール名の付け方の例
・処理内容が推測できる長めの名前を付ける
・動詞に"er"を付ける
・先頭は大文字

モジュール名には動詞に"er"を付け、「~」する人といった意味の名詞になるようにします。

【例】
・TextFileReader(テキストファイル読込用モジュール)
・CSVConverter(CSVからJSONに変換用モジュール)

関数名が動詞になっているので、他モジュールから呼び出した際に名詞.動詞となり、文法的にもわかりやすいですね。

Sample.bas
' 他モジュールの関数呼び出し
call TextFileReader.readTargetFile(fPath)

ただ、共通関数や定数を記述するモジュールは他と区別するために「Util」「Constants」といった名前にしても良いかと思います。

 

日本語、数字は使わない

以下の2つは命名時には出来るだけ使わないようにしましょう。

・日本語
・数字

変数名、関数名に日本語を使うとコメントとそれ以外の区別が付きにくくなってしまいます。

また、数字を付けるのも出来るだけやめましょう。
connect1、connect2、val1など、慣れないうちはついつい数字を末尾につけてしまいますが、これはNGです。
1と2で何が違うのか名前からは分からないためです。

2
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?