
エクセルに配列数式、配列定数というものがあることを最近知りました。
エクセルのA1セルに={1,3,3}と入力し、A2セルに=COUNTIF(A1,{1,2,3})と入力すると、
A2セルに1と表示されます。A2には1以外の数字が含まれることは何となく理解できるのですが、どのような計算結果が算出されるのかが理解できません。また、A2の1以外の計算結果を表示させる方法がわかりません。
同様に、A1セルに={1,2,2,3}と入力し、A2セルに=COUNTIF(A1,{1,2,3})と入力した場合(これもA2セルに1と表示されます)のA2の計算結果と表示方法がわかりません。
ご教示をよろしくお願いいたします。
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.4
- 回答日時:
配列とは、数学で言うところのベクトルあるいは行列だと考えてください。
また、曖昧な言い方ですが、複数セルの集まりのようなものだと思ってください。説明を始めるといろいろな要素があって、なかなか一言では言えないので、他の回答者さんのご説明も参照してください。
とりあえず、配列がどのようなものであるかを感じていただくために、次の操作をしてみてください。何が起こるでしょうか?
1.A1セルに「={1,3,3}」を入力する。
2.A1:C1のセル範囲を選択する。
3.続けて、キーボードのF2キーを押す。
4.続けて、Ctrl+Shift+Enterを押す。
5.A1セルをダブルクリックし、Enterを押すと、「配列の一部を変更できません。」というメッセージが出るので、Escキーでその状態を抜け出す。
6.A1:C1のセル範囲をクリア(delete)する。
7.A1セルに「1」を入力する。
8.上の2.と3.の操作をもう一度、実行する。
9.続けて、Ctrl+Enterを押す。
10.A1セルをダブルクリックし、Enterを押す。
COUNTIF関数について。COUNTIFは、「基本的には」その引数に配列定数を取らない関数です。そういう仕様です。
配列定数を取らないけれどもムリヤリ書いてやると、最初の数字以外は読み飛ばします。つまり「=countif(a1:a3,{1,2,3})」と書いていても、「=countif(a1:a3,1)」と同じ意味になり、「2」や「3」は無視されます。
なので、それでも配列定数を混ぜるためには、No.1さんのおっしゃっているとおり、SUMPRODUCT関数など配列を扱える関数と組み合わせることが必要です。次の2式は、同じ計算結果になります。
=sumproduct(countif(a1:a3,{1,2,3}))
=sum(countif(a1:a3,1),countif(a1:a3,2),countif(a1:a3,3))
引数に配列定数を指定できる関数とそうでない関数があることがわかりました。わかりやすい例を教えていただき、ありがとうございました。
No.3
- 回答日時:
まずは日経21のEXCEL虎の穴をご熟読ください
私はこちらで基礎を叩き込みました
あと、できれば私の過去答の全てを後参照ください
きっと直ぐに私程度には
すらすら書けるように
なれるものと思います。
私自身片手間にほぼ2ヶ月程度で理解しましたから
ただ、厄介でいまだに困らされる点が 幾つかあります。
それは、
→マイクロソフトが配列数式の仕様を
無断で細々と変えてくること。
→配列数式を未経験なエクセルには
ロックがかかってること。
→配列数式の計算結果を
次段の関数に渡す関係で
仕様と言うなのバグがあり、
INDEX構文で一旦、
なんちゃって定数配列に
変えてあげる必要がある。
→数学の配列演算的な空想力が
求められること。
→配列演算では、項目数をきちっと
合わせる必要があること
などです。
この内、数学的云々は
まあ配列を知らなくても、直感的に感じとれば行けると思いますが
INDEXの方はかなり厄介です。
この構文を有機的にかける必要があり、
しかもその位置をマイクロソフトが
関数の使用変更に伴い
非公開でコロコロ変えてくるからです。
余談ですが
このことを知っている人は
この日本でも極少数だと思います。
まあ極意は伝えました
あとは簡単なものでロックをはずし
そのEXCELの表示されない
内部バージョンの仕様にしたがって
INDEXをかけるべきと頃を探せるようになれば
もうしめたものです。
きっと誰にもEXCEL作業ではヒケをとらなくなると思います。
まあ、さらにその先の関数結果の考察についての極意が
まだまだあるのですが
それはまた別の機会に
ところで、今回の引数
({1,2,3},1)も(1,{1,2,3})も実は正しいですよ。
ロックの外れた環境で試せば
楽しめると思います。
おっといい忘れてました
競るに表示される結果は常に一つ
対して、配列数式の結果はしばしば複数になりますよね
どうやって結果を確認するかですが
数式バーで確認したい範囲を謎って
PF9をおせば
結果が数式バーに表示できる範囲の長さならばですが
確認できます。
違う方法としては
INDEXとROWを用いて
複数のセルに結果の一つ一つを表示する方法とかもありますがね。
まあ頑張ってください
配列数式の有用性が広く世に広まれば
EXCELシートプログラマに開発の仕事以来が来るでしょうから
ね、
p.s.
EXCELで表に現れる結果を鵜呑みにしたらダメですよ
例えば、今回挙げられた例では
A2は1と現れていると思いますが
このA2の表示形式を
ユーザー指定形式で
¨¨,¨¨,¨¨,¨¨としてみてください
きっと目を疑うことになると思いますよ
もしかしたら今までのEXCEL作業の危うさにうちひしがれる、
いや、人生観すら揺らぐかも?
見えているものが真実と
信頼できなくなるのですからね
ページを紹介いただきありがとうございました。初心者なので教えていただいたことの全てを理解することができませんが、エクセルは奥が深そうですね。勉強のし甲斐がありそうです。
No.2
- 回答日時:
配列数式のとっかかりは「◆“達人”芳坂和行氏に学ぶ、エクセル(Excel)「配列数式」講座」のページで覚えました
http://pc.nikkeibp.co.jp/pc21/special/hr/
しかし、基本的に作業列を使った方が計算が早く、そのExcelファイルを引き継ぐ人にやさしいです。
No.1
- 回答日時:
>A1セルに={1,3,3}と入力し、A2セルに=COUNTIF(A1,{1,2,3})と入力すると、
その数式では配列計算が出来ていないので、イメージしていた結果も得られません。
といっても、アナタがその式で一体「何を計算したかった」のかイマイチ不明なので、「これが正解です」を掲示する事もできないんですが。
とりあえず。
間違いのその1)
>A1セルに={1,3,3}と入力し、
A2の式中でそのA1セルを参照していますが、そのやり方では配列定数の「先頭の1」が単独で参照されるだけです。配列定数(1と3と3)として呼び込めていません。
任意のセルに
=A1
と数式を記入し、A1セルに記入した配列定数の中身を変えてみて、理解してください。
間違いのその2)
>A2セルに=COUNTIF(A1,{1,2,3})
A2のセルの式の中でも配列定数{1,2,3}を使おうとしていますが、そのやり方では配列定数の「先頭の1」だけしか計算できていません。
間違いのその3)
>A1セルに={1,2,2,3}と入力し、A2セルに=COUNTIF(A1,{1,2,3})と入力した場合のA2の計算結果と表示方法がわかりません
そもそもCOUNTIF関数の1つ目の引数(範囲)には、配列を指定することはできません。セル範囲を指定できるだけです。そのセルに配列定数が記入されていた場合は、先に説明したように先頭の1つだけが参照されます。
間違いのその4)
A1セルに1
A2セルに2
A3セルに2
A4セルに3
をそれぞれ記入します
B1:D1セルを選択
=COUNTIF(A1:A4,{1,2,4})
と記入し、コントロールキーとシフトキーを押しながらEnterして配列入力すると、結果は1,2,0と現れます
縦1×横3のセル範囲に配列入力された3つの数式は、式中の横方向の配列{1,2,4}に対応する位置にある要素を使って計算します。
丁寧に書けば
B1は =COUNTIF(A1:A4,1)
C1は =COUNTIF(A1:A4,2)
D1は =COUNTIF(A1:A4,4)
をそれぞれ計算します。これが配列計算です。
#参考
1つのセルの中で
=SUMPRODUCT(COUNTIF(A1:A4,{1,2,4}))
と計算すると、上述のB1とC1とD1の1,2,0のそれぞれがSUMPRODUCTの中に計算され、合計の3が求まります。
このあたりの計算の流れは、「数式の検証」の機能を使って追跡し勉強できますので参考にしてみて下さい。
質問がわかりにくくて、申し訳ありませんでした。配列を引数に指定できる関数とそうでないものがあることがわかりました。「数式の検証」の機能は計算の過程がわかって便利ですね。ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) ユーザー定義について質問です。 2 2023/06/28 13:21
- Excel(エクセル) エクセルでIF関数中にIFERROR関数を使いたいのですが???? 5 2022/04/08 13:24
- Excel(エクセル) B列に、A列の数字が偶数の場合は1減算した数字、奇数の場合はそのまま数字を自動表示したい 4 2022/04/16 12:01
- Excel(エクセル) 【再度】Excelの関数について教えてください。 4 2023/07/28 13:06
- Excel(エクセル) Excelの関数について教えてください。 5 2023/07/28 11:27
- Excel(エクセル) エクセルVBAでセルに表示されているとおりの数値を取得したい(時間の計算結果) 1 2022/03/30 17:52
- Excel(エクセル) エクセルの数式で教えてください。 2 2022/10/25 17:10
- Excel(エクセル) マクロだと数式が表示される 2 2022/09/10 14:48
- Excel(エクセル) エクセルのことで教えてください。 A1セルに、 別シートのA1セルが1のときは「A」、2のときは「B 4 2023/02/24 23:08
- Excel(エクセル) 現時点の年齢を算出して、その年齢と一致したセルを色付けしたい。 4 2022/06/23 17:49
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
表にフィルターをかけ、絞った...
-
【VBA】ユーザーフォーム リス...
-
16進数から2進数へ
-
[VBA]改行入りのセルの値を配列...
-
VB6.0 ファイルの一括読込み
-
エクセルで、絶対値の平均を算...
-
array関数で格納した配列の型を...
-
Excelでエラー#N/Aを含む最小値...
-
Excelのセルの色指定をVBAから...
-
[エクセル]連続する指定範囲か...
-
Sessionに格納した二次元配列を...
-
ExcelのINDEXとMATCH関数でスピ...
-
Vba Validationの選択状態を知...
-
VBA Dictionaryオブジェクトの...
-
ノーツのデータをVBScriptで取...
-
セルへのデータ入出力を高速で...
-
エクセルVBAで変数をセルに一行...
-
C#での動的配列作成方法について
-
.NET - 配列変数を省略可能の引...
-
CSVファイルの読み込みと表示(V...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで、絶対値の平均を算...
-
[エクセル]連続する指定範囲か...
-
Excelのセルの色指定をVBAから...
-
ExcelのINDEXとMATCH関数でスピ...
-
表にフィルターをかけ、絞った...
-
array関数で格納した配列の型を...
-
【VBA】ユーザーフォーム リス...
-
配列がとびとびである場合の書き方
-
DataSetから、DataTableを取得...
-
読み込みで一行おきに配列に格納
-
エクセルでエラーを無視して一...
-
VBAでの100万行以上のデータの...
-
.NET - 配列変数を省略可能の引...
-
iniファイルのキーと値を取得す...
-
Excel オートフィルタのリスト...
-
SUMPRODUCT関数を用いた最小値
-
VBA 配列に格納した値の平均の...
-
Datatableへの代入
-
VB6.0 ファイルの一括読込み
-
[VBA]改行入りのセルの値を配列...
おすすめ情報