教えて!ExcelVBA!

ExcelVBAの基礎知識・書き方について紹介します。

【ExcelVBA セル操作】セルに関数を使用した数式を入力(Formula)する方法を教えて!

f:id:m_kbou:20200419124510p:plain

セルに関数を使用した数式を入力する方法について説明します。数式を入力するにはFormulaプロパティを使います。また、関数は普通の数式と同じように「=関数名(因数)」で入力する事が可能です。

 

 

構文

記述方法は以下の通りとなります。

Range(”[対象セル]”).Formula = "[関数を使用した数式]"

[説明]:

セルに数式を入力するには

 「Range(”[対象セル]”).Formula = "[関数を使用した数式]"」

と記述します。

[対象セル] 数式をセットするセルを記述します。
※「”」(ダブルクォーテーション)で囲みます。
[関数を使用した数式] 関数を使用した数式を記述します。
※「”」(ダブルクォーテーション)で囲みます。

[記述例]:

Range("A1").Formula = "=SUM(B1:B3)"
Range("A1").Formula = "=AVERAGE(B1:B3)"

 

使い方

使い方について具体的に説明します。

例1:SUM関数を使用したセルに数式を入力する方法

SUM関数を使用したセルに数式を入力する方法について説明します。

[プログラミング例]:

Sub サンプル()

  Range("A1").Formula = "=SUM(B1:B3)"

End Sub

内容は、「A1セルに数式:"=SUM(B1:B3)"をセットして下さい。」との意味になります。

f:id:m_kbou:20210415072706p:plain

※上記の記述例は、VBE(VBA記述画面)に記述しないと実行ができません。VBEの開き方についてはこちらを参考にして下さい。

[実行例]:

①B1セル~B3セルに10~30の数値が入力されています。<実行>ボタンをクリックします。このボタンには上記のプログラミング例のプログラムが登録されています。(※ボタンの作り方やボタンにプログラムを割り当てるにはこちらを参考にして下さい。)

f:id:m_kbou:20210415072720p:plain

②結果としてA1セルに「60」が表示されます。(※A1セルに数式の「=SUM(B1:B3)」がセットされ、B1セル~B3セルの合計値「60」が表示された事が分かります。)

f:id:m_kbou:20210415072734p:plain

[サンプル]:

上記で説明したファイルをダウンロードできます。ご自由にお使い下さい。

drive.google.com

SUM関数を使用したセルに数式を入力する方法についての説明は以上です。

 

例2:AVERAGE関数を使用したセルに数式を入力する方法

AVERAGE関数を使用した数式をセルに入力する方法について説明します。

[プログラミング例]:

Sub サンプル()

  Range("A1").Formula = "=AVERAGE(B1:B3)"

End Sub

内容は、「A1セルに数式:”=AVERAGE(B1:B3)”をセットして下さい。」との意味になります。

f:id:m_kbou:20210415072828p:plain

※上記の記述例は、VBE(VBA記述画面)に記述しないと実行ができません。VBEの開き方についてはこちらを参考にして下さい。

[実行例]:

①B1セル~B3セルに10~30の数値が入力されています。<実行>ボタンをクリックします。このボタンには上記のプログラミング例のプログラムが登録されています。(※ボタンの作り方やボタンにプログラムを割り当てるにはこちらを参考にして下さい。)

f:id:m_kbou:20210415072843p:plain

②結果としてA1セルに「20」が表示されます。(※A1セルに数式の「=AVERAGE(B1:B3)」がセットされ、B1セル~B3セルの平均値「20」が表示された事が分かります。)

f:id:m_kbou:20210415072855p:plain

[サンプル]:

上記で説明したファイルをダウンロードできます。ご自由にお使い下さい。

drive.google.com

AVERAGE関数を使用したセルに数式を入力する方法についての説明は以上です。

 

おわりに

今回は、セルに関数を使用した数式を入力する方法について説明しました。上記以外の関数についても同様に使用する事ができます。是非試してみて下さい。また、類似した内容として、セルに数式を入力する方法もあります。こちらも参考にして下さい。