• ベストアンサー

空白のセルを除いた指定個数の平均

お世話になります。 初めての質問なので失礼がありましたらご容赦ください。 エクセルで空白のセルを除いた指定個数の平均を取りたいと考えております。例えば    A   B  C 1 8月1日  1 2 8月2日  2 3 8月3日  2 4 8月4日  5 8月5日  2 6 8月6日  2 7 8月7日  4 8 8月8日  9 8月9日  2 とあるとします。 C列の位置にB列の過去4日分の空白を除いた平均値を 表示したいのです。 ですので計算結果の例としましては C9が2.5 C7が2.5 C6が2 となります。 空白のセルに規則性はありません。 どなたか教えて頂けませんか?

質問者が選んだベストアンサー

  • ベストアンサー
  • Wendy02
  • ベストアンサー率57% (3570/6232)
回答No.3

こんにちは。 株価グラフには、そういう考え方があったような気がしますね。 ということは、C5 が始まりでよろしいですね。 =SUM(INDEX($B$1:B5,LARGE(INDEX(($B$1:B5<>"")*ROW($B$1:B5),,),4),):B5)/4 これで、下にドラッグ・コピーすれば出来ると思います。

ssg2002
質問者

お礼

出来ました! 確かに株価の整理に使おうと思っていたので 大変助かりました。 どうもありがとうございます!

その他の回答 (2)

  • imogasi
  • ベストアンサー率27% (4737/17069)
回答No.2

勘違いかも知れないが、質問を読んで一瞬、関数では難しいと思った。 それでユーザー関数を作った。 標準モジュールに Function av(a) d = a.Row c = a.Column k = 0 For i = d To 1 Step -1 If Cells(i, c) = "" Then Else k = k + 1 s = s + Cells(i, c) If k = 4 Then av = s / 4 Exit Function End If End If Next av = "" End Function と入れる。 ーー 例データ 8月1日 1 8月2日 2 8月3日 3 8月4日 8月5日 2 2 8月6日 2 2.25 8月7日 4 2.75 8月8日 2.75 8月9日 2 2.5 シートのC1に =av(B1) と入れて式を下方向に複写する。 結果 上記データ例のC列。 ーー 8月8日は空白の方が良いのかな? Function avb(a) If a = "" Then avb = "" Exit Function Else d = a.Row c = a.Column k = 0 For i = d To 1 Step -1 If Cells(i, c) = "" Then Else k = k + 1 s = s + Cells(i, c) If k = 4 Then avb = s / 4 Exit Function End If End If Next i avb = "" Exit Function End If End Function 式は =AVb(B1)

ssg2002
質問者

お礼

出来ました!ありがとうございます! ちなみに 例は4日平均ですが もしも5日平均にするならば If k = 4 Then av = s / 4 の4をそれぞれ5に変えれば良いわけですよね? 本当にありがとうございました!!

  • kirara77
  • ベストアンサー率25% (117/464)
回答No.1

初めまして。 C列の各行に設定する日付判断は、A列の日付で過去4日間のB列セルを選択するか、単純に相対行数で行うかは お好きにされれば良いと思いますが、 空白セルに関して言えば単純に4日分のB列セルをAVERAGE関数を用いて算出すれば良いですよ。 空白セルは計算では無視されますから。

ssg2002
質問者

お礼

質問の内容が悪くて申し訳ございません。 単純に過去4日分ではなく、「B列に数値の入力されている日付の4日分の平均」です。 つまりC9には8月5,6,7,9日の平均値が入るということです。

関連するQ&A