• ベストアンサー

SUMPRODUCT関数について

Excelで=SUMPRODUCT(A1:F1*(MOD(COLUMN(A1:F1),2)=1))という式をIEで検索し使用していますが、なかなか意味がわかりません。 (MOD(COLUMN(A1:F1),2)=1)というところは、列を番号として2で割ったときに1余る列番号を求めているのはわかるのですが、 =SUMPRODUCT(A1:F1*というところが、なぜA1:F1を掛けているのか、どうしてそれで正常な奇数列の和が返ってくるのかがなかなか理解できません。どなたかわかりやすく教えていただけないでしょうか?

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

  • ベストアンサー
  • ja7awu
  • ベストアンサー率62% (292/464)
回答No.1

まず、ヘルプで SUMPRODUCT関数を調べてみましょう。 そこには、「引数として指定した配列の対応する要素間の積をまず計算し、 さらにその和を返します。」とあります。  ↓の式の「引数として指定した配列」は1配列です。(引数が1つより無い) =SUMPRODUCT(A1:F1*(MOD(COLUMN(A1:F1),2)=1)) の (MOD(COLUMN(A1:F1),2)=1)部分は、括弧で括られていることに注目してください。 これは、論理式でA1:F1の範囲で列番号を2で割って残りが1の時、つまり奇数列の とき、真(True)になり、1の値を持っています。 また、偶数列の場合は、論理式は偽(False)になり、0 の値を持っています。 そこで配列が1つですから、「要素間の積」は無く、A1:F1の各値に0か1を掛けた ものの和ということになります。 例えば、今、A1~F1に1~6の数字が入っているとします。 そうすると =SUMPRODUCT(A1:F1*論理式)の部分は、 1*1 + 2*0 + 3*1 + 4*0 + 5*1 + 6*0 ということになり、9 が返ります。 掛け算の最初の数字は、セルの値で後の数字は、論理式の値です。 6個の * が疑問に思っていたのではないでしょうか。 ということで、SUMPRODUCT関数は、論理式と組み合わせて使うと複数条件のカウント や加算する場合に大変便利な関数です。 このような説明でお解りでしょうか。

jinah
質問者

お礼

どうもありがとうございました!!! 丁寧な説明でとても良くわかりました。式の意味がわからないと、応用ができない為、これで色々と試してみようかと思います。

関連するQ&A

専門家に質問してみよう