Ikke alle matrixformler returnerer matrixer med flere kolonner og/eller flere rækker til regnearket. Men når de gør det, kan det ske, at du kun er interesseret i at se én værdi i arrayet. Du kan bruge Excels INDEX-funktion til at hjælpe med det.
For eksempel er LINEST en af regnearksfunktionerne, der kun fungerer korrekt, hvis du array-indtaster formlen, der indeholder funktionen. Men antag, at du kun vil have adgang til én celleværdi i LINEST-resultaterne, måske for at rumme et regnearkslayout i en rutinerapport. I så fald vil du ikke nødvendigvis have det fulde sæt af LINEST resultater, og du kan bruge Excels INDEX-funktion til kun at plukke ud og vise den, du er interesseret i at vise.
For eksempel, her er, hvordan du kan array-indtaste LINEST for en multipel regression:
=LINEST(A2:A51,B2:D51,,SAND)
Hvis du array-indtaster den formel i et 5 rækker gange 4 kolonneområde, vil skæringspunktet mellem det pågældende områdes tredje række og første kolonne indeholde regressionens R-kvadratværdi. Så hvis du kun vælger en enkelt celle og indtaster følgende formel, får du kun R-kvadratværdien:
=INDEKS(LINEST(A2:A51,B2:D51,,SAND),3,1)
Her forsyner du INDEX med den matrix af værdier, der returneres af funktionen LINJEST. Det er det første argument til INDEX. Det andet og tredje argument til INDEX er tallene 3 og 1, som instruerer INDEX om at finde værdien i den tredje række og første kolonne i arrayet og returnere den til regnearket.
Du kan indtaste den fulde INDEX-formel som lige givet normalt, med en matrix af LINEST-resultater som det første argument, uden kombinationen Ctrl og Shift og Enter - det vil sige uden at indtaste den. (Prøv det begge veje, både array ind i det og ind i det normalt.)
Og alligevel, hvis du prøver at indtaste følgende enkeltcelle-arrayformel, frembringer den fejlen #VALUE! hvis du prøver at indtaste det normalt:
=IF(H44639:H44644>0;G44639:G44644,0)
Når formlen kalder en funktion, som Excel forventer at tage en matrix som et argument, kan formlen indtastes normalt. Det er tilfældet med denne formel:
=INDEKS(LINEST(A2:A51,B2:D51,,SAND),3,1)
Resultaterne LINEST er indlejret i INDEX-funktionen, hvor de fungerer som dets første argument. Excel forventer, at INDEX tager en række værdier som dets første argument - at parse en matrix er, hvad INDEX blev født til at gøre. Så formlen som givet behøver ikke at være array-indtastet.
I modsætning hertil skal denne enkeltcelle array-formel indtastes i array:
=MIDDEL(HVIS(A2:A25="Zig",B2:B25,""))
I dette tilfælde forventer Excel ikke, at IF-funktionen vil tage en matrix af værdier som et argument, men her præsenterer vi ikke én men to matrixer af værdier for IF: området A23:A25 og B2:B25. (Du kan endda tage den holdning, at der er en række af 24 forekomster af "" underforstået af de to første argumenter.) Fordi formlen ikke opfylder Excels oprindelige forventning om argumenterne til IF, er du nødt til at henlede Excels opmærksomhed på situationen, og du gør det ved array-indtastning af formlen.