[Office Master] | ||||||||||||
Excelのユーザー定義関数で既存のワークシート関数を利用する
|
||||||||||||
|
解説 |
Windows TIPS「Excelでユーザー定義のワークシート関数を追加する」「ユーザー定義関数で任意のセル範囲の値を取得する」「Excelのユーザー定義関数で複数の結果値を返す」などでも紹介したように、ExcelではVBA(Visual Basic for Application)を利用することで、カスタムのワークシート関数(ユーザー定義関数)を作成できる。
ユーザー定義関数は、標準のワークシート関数では賄いきれない個々人の要件を柔軟に定義できるという意味で貴重なものであるが、実は、一からまったく新しい機能を構築しなければならないというケースはそれほどに多くはないはずだ。というのも、Excelにはデフォルトで数百にも及ぶワークシート関数が用意されており、表計算で必要な機能を満遍なくサポートしているからだ。多くのケースでは、これらデフォルトのワークシート関数を駆使する(または、応用する)だけで十分に要件は満たすことができるはずなのである。
つまり、ユーザー定義関数を作成する場合にも、常に一からロジックを組み立てる必要はないということだ。わざわざいまある機能を自前で構築するのは大きな無駄であるし、そもそも無用なバグの原因にもなる。いままで使い込まれた機能がすでに存在するならば、なるべくそれらを利用することを考えるべきだろう。
そこで本TIPSでは、ユーザー定義関数(正確には、ユーザー定義関数の実体であるFunctionプロシージャ)から既存のワークシート関数を呼び出す方法を紹介する。この方法を用いることで、ユーザー定義関数では標準のワークシート関数に対して追加/変更したい差分のロジックだけを記述すれば済むようになるので、より簡単にユーザー定義関数を作成できる。
操作方法 |
本稿では、Windows TIPS「Excelのユーザー定義関数で複数の結果値を返す」でも紹介したSumAvg関数を、ワークシート関数を引用しつつ書き換えてみることにしたい。
このTIPSでも紹介したように、SumAvg関数は、指定されたセル範囲に含まれる値に関して、合計値と平均値とを返すユーザー定義関数だ。しかし、合計値/平均値ともに、これを算出するための関数は、単体ではすでに標準のワークシート関数として用意されている。よくご存じであろうSum関数とAverage関数だ。ここでは、これらの関数を、ユーザー定義関数を定義したFunctionプロシージャから実際に呼び出してみることにしよう。先のTIPSで紹介したコードは、以下のように書き換えることができる。
Function SumAvg(範囲 As Range) |
- サンプル・ファイルのダウンロード
(注:サンプル・ファイルをダウンロードするには、上のリンクを右クリックしてarrayfnc.xlsというファイル名で保存する)
ワークシート関数を呼び出すには、一般的に以下の書式で行うことが可能だ。
WorksheetFunction.ワークシート関数(引数,....) |
ワークシート関数の頭にWorksheetFunctionオブジェクトを指定するだけなので、ワークシート上で利用する場合とほとんど同じ要領で使用できることがお分かりになるはずだ。
別稿で紹介したのと同じ要領でSumAvg関数を実行してみると、確かに横並びのセルに、それぞれセル範囲の合計値と平均値とが返されているのが確認できるはずだ。
■
ただしVBA上でワークシート関数を利用する場合、1点だけ注意しなければならないことがある。それはセル範囲の渡し方だ。ワークシート上では、セル範囲を「セルA:セルB」の形式で指定する。例えば次のようにする。
Sum(A1:A10) |
しかし、VBA上ではこのような指定はできない。これは、Windows TIPS「ユーザー定義関数で任意のセル範囲の値を取得する」でも紹介したように、セル範囲はあくまで内部的にはRangeオブジェクトとして認識されるものだからだ。「セルA:セルB」の形式で指定しても、VBA上では単なる文字列としてしか認識されない。よって、上の例ならば、VBA上では以下のように記述する必要がある。
WorksheetFunction.Sum(Range("A1:A10")) |
関連記事 | ||
Windows TIPS:Excelでユーザー定義のワークシート関数を追加する(Windows Server Insider) | ||
Windows TIPS:ユーザー定義関数で任意のセル範囲の値を取得する(Windows Server Insider) | ||
Windows TIPS:Excelのユーザー定義関数で複数の結果値を返す(Windows Server Insider) | ||
この記事と関連性の高い別の記事
- ユーザー定義関数で任意のセル範囲の値を取得する(TIPS)
- Excelでユーザー定義のワークシート関数を追加する(TIPS)
- Excelのユーザー定義関数で複数の結果値を返す(TIPS)
- Excelでユーザー定義関数をエクスポート/インポートする(TIPS)
- VLOOKUP関数でExcel帳票への自動入力を可能にする(TIPS)
このリストは、デジタルアドバンテージが開発した自動関連記事探索システム Jigsaw(ジグソー) により自動抽出したものです。
「Windows TIPS」 |
- Azure Web Appsの中を「コンソール」や「シェル」でのぞいてみる (2017/7/27)
AzureのWeb Appsはどのような仕組みで動いているのか、オンプレミスのWindows OSと何が違うのか、などをちょっと探訪してみよう - Azure Storage ExplorerでStorageを手軽に操作する (2017/7/24)
エクスプローラのような感覚でAzure Storageにアクセスできる無償ツール「Azure Storage Explorer」。いざというときに使えるよう、事前にセットアップしておこう - Win 10でキーボード配列が誤認識された場合の対処 (2017/7/21)
キーボード配列が異なる言語に誤認識された場合の対処方法を紹介。英語キーボードが日本語配列として認識された場合などは、正しいキー配列に設定し直そう - Azure Web AppsでWordPressをインストールしてみる (2017/7/20)
これまでのIaaSに続き、Azureの大きな特徴といえるPaaSサービス、Azure App Serviceを試してみた! まずはWordPressをインストールしてみる
|
|